A pandemia global CoronaVirus COVID-19, também chamada de SARS-CoV-2, já afetou milhões de pessoas em todo o mundo. O COVID-19 Web App é um protótipo de aplicativo em nuvem desenvolvido em Python e Flask que fornece estatísticas globais dos casos afetados pelo COVID-19. Este aplicativo utiliza um serviço REST API para obter as estatísticas diárias do COVID-19 e o aplicativo é implantado na instância AWS EC2.
Obtenha o resumo de todos os países e estatísticas globais.
Obtenha a lista de todos os países junto com os detalhes do slug e do código do país.
Isso carrega o banco de dados com estatísticas do país COVID 19 usando a API externa 'https://api.covid19api.com/summary'
A página inicial exibe as estatísticas globais do COVID 19, juntamente com links para visualizar as estatísticas do país e a interação com a API REST externa. Pode-se usar o comando curl:
Obtenha as estatísticas de todos os países do banco de dados. Pode ser executado usando o seguinte comando curl:
curl -i -k https://0.0.0.0/summary/country
Obtenha as estatísticas globais do banco de dados. Pode ser executado usando o seguinte comando curl:
curl -i -k https://0.0.0.0/summary/global
Obtenha as estatísticas específicas do país no banco de dados. Pode ser executado usando o seguinte comando curl:
curl -i -k https://0.0.0.0/summary/country/TestCountry
Adicione um novo país ao banco de dados. O usuário deve fornecer o seguinte:
Esta é uma solicitação POST e pode ser executada usando o seguinte 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
Atualize um país existente no banco de dados. O usuário deve fornecer o seguinte:
Esta é uma solicitação PUT e pode ser executada usando o seguinte 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
Exclui um registro de país do banco de dados. O usuário deve fornecer o seguinte:
Esta é uma solicitação DELETE e pode ser executada usando o seguinte comando curl:
curl -i -k -H "Content-Type: application/json" -X DELETE -d '{"Country":"TestCountry"}' https://0.0.0.0/summary/country
Adicione as estatísticas globais ao banco de dados. O usuário deve fornecer o seguinte:
Aqui, 'chave' refere-se ao valor 'Global'. Esta é uma solicitação POST e pode ser executada usando o seguinte 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
Atualiza as estatísticas globais no banco de dados. O usuário deve fornecer o seguinte:
Aqui, 'chave' refere-se ao valor 'Global'. Esta é uma solicitação PUT e pode ser executada usando o seguinte 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
Exclui o registro de estatísticas globais do banco de dados. O usuário deve fornecer o seguinte:
*Chave
Aqui, 'chave' refere-se ao valor 'Global'. Esta é uma solicitação DELETE e pode ser executada usando o seguinte 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;
O aplicativo é servido por https configurando os certificados autoassinados conforme mostrado abaixo:
$ 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)
Abaixo estão as etapas para construir a imagem docker e implantar o aplicativo no 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: Esta etapa é opcional e deve ser executada somente se o docker push falhar.
sudo systemectl restart docker
sudo docker start cassandra-test
sudo microk8s.kubectl apply -f ./deployment.yaml
O aplicativo we agora está implantado em 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
Abaixo está o exemplo de status do serviço:
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
Aqui podemos ver que o aplicativo da web implantado está exposto ao Nodeport '30873'. Por padrão, o serviço Kubernetes aloca uma porta no intervalo ‘30000-32767’.
Por fim, visualize o aplicativo da web no navegador usando o DNS público da conta AWS EC2 junto com este Nodeport que começa com '30xxx'.
sudo microk8s.kubectl delete deployment covidapp-deployment
sudo microk8s.kubectl delete service covidapp-deployment
sudo docker rm cassandra-test