Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aliartiza75/flask-backend-application
Back-end application build in flask, its frontend application exists in aliartiza75/ht-fe repository.
https://github.com/aliartiza75/flask-backend-application
docker flask-restapi flask-restful helm kubernetes microservice
Last synced: about 1 month ago
JSON representation
Back-end application build in flask, its frontend application exists in aliartiza75/ht-fe repository.
- Host: GitHub
- URL: https://github.com/aliartiza75/flask-backend-application
- Owner: aliartiza75
- Created: 2019-02-09T06:57:29.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-10-28T11:50:20.000Z (4 months ago)
- Last Synced: 2024-11-18T08:29:15.780Z (3 months ago)
- Topics: docker, flask-restapi, flask-restful, helm, kubernetes, microservice
- Language: Python
- Homepage:
- Size: 72.3 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
[data:image/s3,"s3://crabby-images/9ae1b/9ae1b96884ce83d20dee713e7adccc38a71bd831" alt="SonarCloud"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/0d4ca/0d4caf530ef176e91a7cad0b07a70462114be272" alt="Quality gate"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/10b43/10b43a21cce99acee4d93989b65179dcec85d1fb" alt="Quality Gate Status"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/4f713/4f713eb6c745f959dd925463be90f286bec86efd" alt="Bugs"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/c29fd/c29fdd2eed7f5c1364c79903922f62d869c04dc1" alt="Code Smells"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/09fae/09faee6f5ac7921b661da981cd2216a6b26a6dff" alt="Duplicated Lines (%)"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/34896/34896031e8e70b42c2f9e5252a10978d79a04039" alt="Lines of Code"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/4c121/4c12175d8d4711ef38a35fefa1dabb454036a7c6" alt="Maintainability Rating"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/10b43/10b43a21cce99acee4d93989b65179dcec85d1fb" alt="Quality Gate Status"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/0b2b3/0b2b380abbbbba616f933ad2e79cc25af06eac41" alt="Reliability Rating"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/4994d/4994dd113e31420876ed44e9b4a7f1d48a713833" alt="Security Rating"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/bb15b/bb15bf2207cc2bd2dd4f73d880783160b8e7323f" alt="Technical Debt"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)
[data:image/s3,"s3://crabby-images/102be/102befd43cb5e478fc1aa88e476b18c23685df73" alt="Vulnerabilities"](https://sonarcloud.io/summary/new_code?id=aliartiza75_flask-backend-application)# Flask Backend Application
This repository contains backend logic and kubernetes manifests. I have used `minikube` for this project. Installation steps is given in this [gist](https://gist.github.com/aliartiza75/3a34f059de62c7de04727dae6a363ea8)
# Guidelines for containerizing backend
* To build image
```bash
sudo docker run -t ht-be:0.0.1 -f Dockerfile .
```* To run docker container on host machine
```bash
sudo docker run -e FLASK_ENV=development -e FLASK_HOST_IP=0.0.0.0 -e=FLASK_HOST_PORT=5001 -e Name=Irtiza -p 1001:5001 ht-be:0.0.1
```# Guidelines for kubernetes deployment
* Deployment creation
```bash
sudo kubectl apply -f deployment.yaml
```* Service creation
```bash
sudo kubectl apply -f htbe_service.yaml
```* Validating whether application is running or not. Use the command given below from host machine on which kubernetes is running
```
curl -X GET "http://:/datetime"
```# Guidelines for helm charts deployment
* Helm installation guidelines [link](https://helm.sh/docs/install/#installing-the-helm-client)* Once the helm is installed, use the command given below to install tiller in kubernetes cluster:
```bash
helm init
```* To create a helm chart folder:
```bash
helm create
```* To dry run the helm chart for debugging:
```bash
sudo helm install --dry-run --debug
```* To purge a release
```bash
sudo helm del --purge
```* To check the status of a release
```bash
sudo helm ls --all
```* To search a helm package name
```bash
sudo helm search
```* To create a package from the helm charts folder
```bash
sudo helm package
```# Important Notes
* Start the minikube cluster in the virtual machine drive in none mode [--vm-driver=none], otherwise services will not be accessible.
* Minikube will pull images from the dockerhub.
* In some cases minikube cluster doesn't work properly, one quick fix is to delete the cluster and restart the minikube cluster.