python-flask-aws-terraform
python-flask-aws-terraform copied to clipboard
Deploy a Python Flask app onto Amazon ECS on AWS Fargate with Terraform
AWS Fargate Python Flask App
A reference project to deploy a Python Flask app onto Amazon ECS on AWS Fargate with Terraform. Inspired by this AWS tutorial
A todo app creating, and retrieving data from Amazon RDS
Pre-requisite
- Make sure you have installed Python 3, pip, Terraform, AWS CLI, and configured a
defaultAWS CLI profile (see doc here)
terraform -help # prints Terraform options
which aws # prints /usr/local/bin/aws
aws --version # prints aws-cli/2.0.36 Python/3.7.4 Darwin/18.7.0 botocore/2.0.0
aws configure # configure your AWS CLI profile
python3 --version # prints Python 3 version
pip3 --version # prints pip version
Run/Build app locally
- In a seperate terminal window, run
docker-compose -f docker-compose.dev.yml upto run PostgreSQL database inside a container. Then, return to the original terminal window and run the following commands:
virtualenv -p /usr/bin/python3 venv # create new virtual environment venv
source venv/bin/activate # activate venv
pip3 install -r requirements.txt # installs python packages
python3 manage.py # visit app at http://localhost:5000/ping
deactivate # deactivates venv
Install new packages
pip3 install boto # installs new Python package
pip3 freeze > requirements.txt # updates requirements.txt
Run app in container
- Run
docker-compose upto start app in container. Alternatively, you may choose to build, and run theapiapp image:
docker build -t matlau/python-flask-aws:latest . # build Docker image
docker run -p 5000:5000 matlau/python-flask-aws # visit app at http://localhost:5000/ping
Configuration
-
Create an S3 bucket to store Terraform state. Populate bucket name in
01-main.tf -
Create a secret on AWS Secrets Manager named
RDSPostgresPasswordwith keyPOSTGRES_PASSWORD, and your database password as value -
Populate
terraform.tfvars:
default_region = "<YOUR_AWS_DEFAULT_REGION>"
app_name = "<GIVE_YOUR_APP_A_NAME!>"
environment = "<ENVIRONMENT_NAME>"
Deploy AWS stack
cd deploy # change to deploy directory
terraform init # initialises Terraform
terraform apply # deploys AWS stack. See output for API url
terraform destroy # destroys AWS stack
Contributing
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update tests as appropriate
If you find this project helpful, please give a :star: or even better buy me a coffee :coffee: :point_down: because I'm a caffeine addict :sweat_smile:
