全球大流行的冠狀病毒 COVID-19(也稱為 SARS-CoV-2)已經影響了全世界數百萬人。 COVID-19 Web 應用程式是使用 Python 和 Flask 開發的雲端應用程式原型,可提供受 COVID-19 影響的病例的全球統計數據。該應用程式利用 REST API 服務來獲取 COVID-19 的每日統計數據,並且該應用程式部署在 AWS EC2 執行個體中。
取得所有國家和全球統計數據的摘要。
取得所有國家/地區的清單以及名稱和國家/地區代碼詳細資訊。
這將使用外部 API「https://api.covid19api.com/summary」載入包含 COVID 19 國家統計資料的資料庫
主頁顯示了 COVID 19 的全球統計數據以及用於查看國家/地區統計數據以及與外部 REST API 互動的連結。可以使用curl指令:
從資料庫中取得所有國家的統計資料。可以使用以下curl指令執行:
curl -i -k https://0.0.0.0/summary/country
從資料庫中取得全域統計資料。可以使用以下curl指令執行:
curl -i -k https://0.0.0.0/summary/global
從資料庫中取得特定國家/地區的統計資料。可以使用以下curl指令執行:
curl -i -k https://0.0.0.0/summary/country/TestCountry
將新國家/地區新增至資料庫。使用者必須提供以下資訊:
這是一個POST請求,可以使用以下curl指令來執行:
curl -i -k -H "Content-Type: application/json" -X POST -d '{"NewConfirmed":2,"TotalConfirmed":3,"NewDeaths":3,"TotalDeaths":3,"NewRecovered":3,"TotalRecovered":3,"Country":"TestCountry"}' https://0.0.0.0/summary/country
將現有國家更新到資料庫。使用者必須提供以下資訊:
這是一個 PUT 請求,可以使用以下curl 指令執行:
curl -i -k -H "Content-Type: application/json" -X PUT -d '{"NewConfirmed":999,"TotalConfirmed":3,"NewDeaths":3,"TotalDeaths":3,"NewRecovered":3,"TotalRecovered":3,"Country":"TestCountry"}' https://0.0.0.0/summary/country
從資料庫中刪除國家/地區記錄。使用者必須提供以下資訊:
這是一個 DELETE 請求,可以使用以下curl指令執行:
curl -i -k -H "Content-Type: application/json" -X DELETE -d '{"Country":"TestCountry"}' https://0.0.0.0/summary/country
將全域統計資訊新增至資料庫。使用者必須提供以下資訊:
這裡的「key」指的是值「Global」。這是一個 POST 請求,可以使用以下命令執行:
curl -i -k -H "Content-Type: application/json" -X POST -d '{"NewConfirmed":9,"TotalConfirmed":3,"NewDeaths":3,"TotalDeaths":3,"NewRecovered":3,"TotalRecovered":3,"Key":"TestGlobal"}' https://0.0.0.0/summary/global
將全域統計資料更新到資料庫。使用者必須提供以下資訊:
這裡的「key」指的是值「Global」。這是一個 PUT 請求,可以使用以下命令執行:
curl -i -k -H "Content-Type: application/json" -X PUT -d '{"NewConfirmed":1,"TotalConfirmed":10,"NewDeaths":3,"TotalDeaths":3,"NewRecovered":3,"TotalRecovered":3,"Key":"TestGlobal"}' https://0.0.0.0/summary/global
從資料庫中刪除全域統計記錄。使用者必須提供以下資訊:
*鑰匙
這裡的「key」指的是值「Global」。這是一個 DELETE 請求,可以使用下列命令執行:
curl -i -k -H "Content-Type: application/json" -X DELETE -d '{"Key":"TestGlobal"}' https://0.0.0.0/summary/global
sudo apt update
sudo apt install docker.io
sudo docker pull cassandra:latest
sudo docker run --name cassandra-test -p 9042:9042 -d cassandra:latest
wget https://raw.githubusercontent.com/niranjanganesan/ECS781P_Cloud_Computing_Mini_Project/master/country.csv
wget https://raw.githubusercontent.com/niranjanganesan/ECS781P_Cloud_Computing_Mini_Project/master/global.csv
sudo docker cp country.csv cassandra-test:/home/country.csv
sudo docker cp global.csv cassandra-test:/home/global.csv
sudo docker exec -it cassandra-test cqlsh
cqlsh> CREATE KEYSPACE COVID19 WITH REPLICATION = {'class': 'SimpleStrategy', 'replication_factor': '1'};
cqlsh> CREATE TABLE COVID19.summary (Country text PRIMARY KEY,NewConfirmed int,
TotalConfirmed int, NewDeaths int, TotalDeaths int, NewRecovered int,
TotalRecovered int);
cqlsh> CREATE TABLE COVID19.global (Key text PRIMARY KEY,NewConfirmed int,
TotalConfirmed int, NewDeaths int, TotalDeaths int, NewRecovered int,
TotalRecovered int, TimeStamp text);
cqlsh> COPY COVID19.summary(Country, NewConfirmed, TotalConfirmed, NewDeaths, TotalDeaths, NewRecovered, TotalRecovered)
FROM '/home/country.csv' WITH HEADER=TRUE;
cqlsh> COPY COVID19.global(Key, NewConfirmed, TotalConfirmed, NewDeaths, TotalDeaths, NewRecovered, TotalRecovered)
FROM '/home/global.csv' WITH HEADER=TRUE;
該應用程式透過設定自簽名憑證透過 https 提供服務,如下所示:
$ openssl req -x509 -newkey rsa:4096 -nodes -out cert.pem -keyout key.pem -days 365
Generating a RSA private key
.....................................++++
....................................................................................++++
writing new private key to 'key.pem'
-----
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [AU]:UK
State or Province Name (full name) [Some-State]:England
Locality Name (eg, city) []:London
Organization Name (eg, company) [Internet Widgits Pty Ltd]:QMUL
Organizational Unit Name (eg, section) []:
Common Name (e.g. server FQDN or YOUR name) []:localhost
Email Address []:[email protected]
if __name__ == "__main__":
context = ('cert.pem','key.pem')
app.run(host='0.0.0.0',port=443,ssl_context=context)
以下是在 kubernetes 中建置 docker 映像和部署應用程式的步驟
sudo snap install microk8s --classic
sudo microk8s enable registry
apiVersion: apps/v1
kind: Deployment
metadata:
name: covidapp-deployment
labels:
app: covidapp
spec:
selector:
matchLabels:
app: covidapp
replicas: 3
template:
metadata:
labels:
app: covidapp
spec:
containers:
- name: covidapp
image: localhost:32000/covidapp:registry
ports:
- containerPort: 443
sudo docker build . -t localhost:32000/covidapp:registry
sudo docker push localhost:32000/covidapp:registry
{
"insecure-registries" : ["localhost:32000"]
}
注意:此步驟是可選的,只有在 docker Push 失敗時才必須執行。
sudo systemectl restart docker
sudo docker start cassandra-test
sudo microk8s.kubectl apply -f ./deployment.yaml
we應用程式現已部署在kubernetes中
sudo microk8s.kubectl get deployment
sudo microk8s.kubectl get pods
sudo microk8s.kubectl expose deployment covidapp-deployment --port=443 --type=LoadBalancer
sudo microk8s.kubectl get services
以下是服務的狀態範例:
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/covidappv3-deployment LoadBalancer 10.152.183.77 <pending> 443:30873/TCP 17h
service/kubernetes ClusterIP 10.152.183.1 <none> 443/TCP 9d
在這裡我們可以看到部署的 Web 應用程式暴露給 Nodeport「30873」。預設情況下,kubernetes 服務會指派「30000-32767」範圍內的連接埠。
最後,使用 AWS EC2 帳戶的公共 DNS 以及以「30xxx」開頭的 Nodeport 在瀏覽器中查看 Web 應用程式。
sudo microk8s.kubectl delete deployment covidapp-deployment
sudo microk8s.kubectl delete service covidapp-deployment
sudo docker rm cassandra-test