Глобальная пандемия Коронавируса COVID-19, также известного как SARS-CoV-2, уже затронула миллионы людей во всем мире. Веб-приложение COVID-19 — это прототип облачного приложения, разработанного на Python и Flask, которое предоставляет глобальную статистику случаев заражения COVID-19. Это приложение использует службу REST API для получения ежедневной статистики о COVID-19, и приложение развертывается в экземпляре AWS EC2.
Получите сводную информацию по всем странам и глобальную статистику.
Получите список всех стран вместе с информацией о ярлыке и коде страны.
Это загружает базу данных со статистикой страны по COVID 19 с использованием внешнего API «https://api.covid19api.com/summary».
На главной странице отображается глобальная статистика по 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
Добавьте глобальную статистику в базу данных. Пользователь должен предоставить следующее:
Здесь «ключ» относится к значению «Глобальное». Это запрос 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
Обновляет глобальную статистику в базе данных. Пользователь должен предоставить следующее:
Здесь «ключ» относится к значению «Глобальное». Это запрос 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
Удаляет запись глобальной статистики из базы данных. Пользователь должен предоставить следующее:
*Ключ
Здесь «ключ» относится к значению «Глобальное». Это запрос 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)
Ниже приведены шаги по созданию образа Docker и развертыванию приложения в 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"]
}
Примечание. Этот шаг является необязательным и его необходимо выполнять только в том случае, если не удалось выполнить отправку Docker.
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
Здесь мы видим, что развернутое веб-приложение доступно для Nodeport «30873». По умолчанию служба kubernetes выделяет порт в диапазоне «30000–32767».
Наконец, просмотрите веб-приложение в браузере, используя общедоступный DNS учетной записи AWS EC2 вместе с этим Nodeport, который начинается с «30xxx».
sudo microk8s.kubectl delete deployment covidapp-deployment
sudo microk8s.kubectl delete service covidapp-deployment
sudo docker rm cassandra-test