Die globale Pandemie Coronavirus COVID-19, auch SARS-CoV-2 genannt, hat bereits Millionen Menschen auf der ganzen Welt betroffen. Die COVID-19-Web-App ist ein Prototyp einer in Python und Flask entwickelten Cloud-Anwendung, die globale Statistiken über von COVID-19 betroffene Fälle liefert. Diese App nutzt einen REST-API-Dienst, um die täglichen Statistiken zu COVID-19 abzurufen, und die Anwendung wird in der AWS EC2-Instanz bereitgestellt.
Erhalten Sie die Zusammenfassung aller Länder und globalen Statistiken.
Holen Sie sich die Liste aller Länder zusammen mit Slug- und Ländercode-Details.
Dadurch wird die Datenbank mit COVID-19-Länderstatistiken über die externe API „https://api.covid19api.com/summary“ geladen.
Auf der Startseite werden die globalen Statistiken zu COVID 19 sowie Links zum Anzeigen der länderbezogenen Statistiken und zur Interaktion mit der externen REST-API angezeigt. Man kann den Curl-Befehl verwenden:
Holen Sie sich die Statistiken aller Länder aus der Datenbank. Kann mit dem folgenden Curl-Befehl ausgeführt werden:
curl -i -k https://0.0.0.0/summary/country
Rufen Sie die globalen Statistiken aus der Datenbank ab. Kann mit dem folgenden Curl-Befehl ausgeführt werden:
curl -i -k https://0.0.0.0/summary/global
Rufen Sie die länderspezifischen Statistiken aus der Datenbank ab. Kann mit dem folgenden Curl-Befehl ausgeführt werden:
curl -i -k https://0.0.0.0/summary/country/TestCountry
Fügen Sie der Datenbank ein neues Land hinzu. Der Benutzer muss Folgendes bereitstellen:
Dies ist eine POST-Anfrage und kann mit dem folgenden Curl-Befehl ausgeführt werden:
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
Aktualisieren Sie ein vorhandenes Land in der Datenbank. Der Benutzer muss Folgendes bereitstellen:
Dies ist eine PUT-Anfrage und kann mit dem folgenden Curl-Befehl ausgeführt werden:
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
Löscht einen Ländereintrag aus der Datenbank. Der Benutzer muss Folgendes bereitstellen:
Dies ist eine DELETE-Anfrage und kann mit dem folgenden Curl-Befehl ausgeführt werden:
curl -i -k -H "Content-Type: application/json" -X DELETE -d '{"Country":"TestCountry"}' https://0.0.0.0/summary/country
Fügen Sie die globalen Statistiken zur Datenbank hinzu. Der Benutzer muss Folgendes bereitstellen:
Hier bezieht sich „Schlüssel“ auf den Wert „Global“. Dies ist eine POST-Anfrage und kann mit dem folgenden Befehl ausgeführt werden:
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
Aktualisiert die globalen Statistiken in der Datenbank. Der Benutzer muss Folgendes bereitstellen:
Hier bezieht sich „Schlüssel“ auf den Wert „Global“. Dies ist eine PUT-Anfrage und kann mit dem folgenden Befehl ausgeführt werden:
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
Löscht den globalen Statistikdatensatz aus der Datenbank. Der Benutzer muss Folgendes bereitstellen:
*Schlüssel
Hier bezieht sich „Schlüssel“ auf den Wert „Global“. Dies ist eine DELETE-Anfrage und kann mit dem folgenden Befehl ausgeführt werden:
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;
Die App wird über https bereitgestellt, indem die selbstsignierten Zertifikate wie unten gezeigt eingerichtet werden:
$ 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)
Nachfolgend finden Sie die Schritte zum Erstellen des Docker-Images und zum Bereitstellen der Anwendung in Kubernetes
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"]
}
Hinweis: Dieser Schritt ist optional und muss nur durchgeführt werden, wenn Docker Push fehlgeschlagen ist.
sudo systemectl restart docker
sudo docker start cassandra-test
sudo microk8s.kubectl apply -f ./deployment.yaml
Die we-App wird jetzt in Kubernetes bereitgestellt
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
Nachfolgend finden Sie den Beispielstatus des Dienstes:
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
Hier sehen wir, dass die bereitgestellte Web-App dem Nodeport „30873“ ausgesetzt ist. Standardmäßig weist der Kubernetes-Dienst einen Port im Bereich „30000-32767“ zu.
Zeigen Sie abschließend die Web-App im Browser an, indem Sie das öffentliche DNS des AWS EC2-Kontos zusammen mit diesem Nodeport verwenden, der mit „30xxx“ beginnt.
sudo microk8s.kubectl delete deployment covidapp-deployment
sudo microk8s.kubectl delete service covidapp-deployment
sudo docker rm cassandra-test