La pandemia mundial CoronaVirus COVID-19, también llamada SARS-CoV-2, ya ha afectado a millones de personas en todo el mundo. La aplicación web COVID-19 es un prototipo de aplicación en la nube desarrollada en Python y Flask que brinda estadísticas globales de casos afectados por COVID-19. Esta aplicación hace uso de un servicio API REST para obtener las estadísticas diarias de COVID-19 y la aplicación se implementa en la instancia AWS EC2.
Obtenga el resumen de todos los países y estadísticas globales.
Obtenga la lista de todos los países junto con los detalles del código de país y slug.
Esto carga la base de datos con estadísticas del país de COVID 19 utilizando la API externa 'https://api.covid19api.com/summary'
La página de inicio muestra las estadísticas globales de COVID 19 junto con enlaces para ver las estadísticas nacionales y la interacción con la API REST externa. Se puede usar el comando curl:
Obtenga las estadísticas de todos los países de la base de datos. Se puede ejecutar usando el siguiente comando curl:
curl -i -k https://0.0.0.0/summary/country
Obtenga las estadísticas globales de la base de datos. Se puede ejecutar usando el siguiente comando curl:
curl -i -k https://0.0.0.0/summary/global
Obtenga las estadísticas específicas del país de la base de datos. Se puede ejecutar usando el siguiente comando curl:
curl -i -k https://0.0.0.0/summary/country/TestCountry
Agregue un nuevo país a la base de datos. El usuario deberá proporcionar lo siguiente:
Esta es una solicitud POST y se puede ejecutar utilizando el siguiente comando 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
Actualizar un país existente en la base de datos. El usuario deberá proporcionar lo siguiente:
Esta es una solicitud PUT y se puede ejecutar usando el siguiente comando 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
Elimina un registro de país de la base de datos. El usuario deberá proporcionar lo siguiente:
Esta es una solicitud DELETE y se puede ejecutar usando el siguiente comando curl:
curl -i -k -H "Content-Type: application/json" -X DELETE -d '{"Country":"TestCountry"}' https://0.0.0.0/summary/country
Agregue las estadísticas globales a la base de datos. El usuario deberá proporcionar lo siguiente:
Aquí, "clave" se refiere al valor "Global". Esta es una solicitud POST y se puede ejecutar usando el siguiente comando:
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
Actualiza las estadísticas globales a la base de datos. El usuario deberá proporcionar lo siguiente:
Aquí, "clave" se refiere al valor "Global". Esta es una solicitud PUT y se puede ejecutar usando el siguiente comando:
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
Elimina el registro de estadísticas globales de la base de datos. El usuario deberá proporcionar lo siguiente:
*Llave
Aquí, "clave" se refiere al valor "Global". Esta es una solicitud DELETE y se puede ejecutar usando el siguiente comando:
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;
La aplicación se entrega a través de https configurando los certificados autofirmados como se muestra a continuación:
$ 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)
A continuación se detallan los pasos para crear la imagen de la ventana acoplable e implementar la aplicación en 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"]
}
Nota: Este paso es opcional y debe realizarse solo si la inserción de Docker falló.
sudo systemectl restart docker
sudo docker start cassandra-test
sudo microk8s.kubectl apply -f ./deployment.yaml
La aplicación we ahora está implementada en 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
A continuación se muestra el estado de muestra del servicio:
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
Aquí podemos ver que la aplicación web implementada está expuesta al Nodeport '30873'. De forma predeterminada, el servicio Kubernetes asigna un puerto dentro del rango '30000-32767'.
Finalmente, vea la aplicación web en el navegador utilizando el DNS público de la cuenta AWS EC2 junto con este Nodeport que comienza con '30xxx'.
sudo microk8s.kubectl delete deployment covidapp-deployment
sudo microk8s.kubectl delete service covidapp-deployment
sudo docker rm cassandra-test