Skip to content

A sample project for a scalable REST API using Django & Django REST Framework, ready to be deployed in AWS with Docker and CDK

Notifications You must be signed in to change notification settings

marianobrc/scalable-django-rest

Repository files navigation

Scalable Django REST

A sample project for REST APIs using Django & Django REST Framework, ready to be deployed in AWS with Docker and CDK.

At the root of this repository you will find a CDK (v2) project.

You will find the Django project and more details about how to set up the development environment is inside the src/ directory.

The Architecture Features

  • A load-balanced, highly-available, auto-scalable Django app running in Amazon ECS+Fargate (a.k.a Serverless Containers).
  • A fully-managed serverless database using Amazon Aurora Serverless.
  • Fully-managed Queues and auto-scalable Workers to run async tasks using Amazon SQS and Celery Workers running in Amazon ECS+Fargate.
  • Static files are stored in a private S3 bucket and served through CloudFront.
  • Private Isolated subnets and VPC Endpoints are used for improved security and performance, also allowing to remove NAT GWs.
  • Sensitive data such as API KEYs or Passwords are stored in AWS Secrets Manager. Other parameters are stored in AWS SSM Parameter Store.

DevOps

  • IaC support using CDK v2
  • CI/CD using CDK Pipelines
  • Docker support for local development with docker-compose.

CDK

The entrypoint for the CDK project is app.py. Other Stacks and stages are defined in scalable_django_rest/.

Prerequisites to work with CDK

  • Python 3.6 or later including pip and virtualenv.

  • Node.js 10.13.0 or later

  • Install the aws client v2:

    https://docs.aws.amazon.com/cli/latest/userguide/install-cliv2-mac.html

  • Setup API Keys of an administrator user and set the region running:

    aws configure

    CDK requires API KEYs with enough permissions to create and destroy resources in your AWS Account. Hence, it's recommended to create a user with Administrator role.

  • Install the cdk client:

    npm install -g aws-cdk

Working with CDK

To work with CDK first activate the virtualenv located at .venv and install dependencies.

$ source .venv/bin/activate
(.venv) $ pip install -r requirements.txt
(.venv) $ pip install -r requirements-dev.txt

Bootstrapping

The usage of CDK Pipelines require an extra command, cdk bootstrap, to provision resources used by CDK during the deploy. This command needs to be executed once per account/region combination as: cdk bootstrap ACCOUNT-NUMBER/REGION.

(.venv) $ cdk bootstrap aws://123456789123/us-east-1
 ⏳  Bootstrapping environment aws://123456789123/us-east-1...
...
 ✅  Environment aws://123456789123/us-east-1 bootstrapped

Deploying to AWS

Set up CDK environment variables

The required env vars for CDK can be found in .env.template You can either set them manually or, if using linux, use the helper script ./scripts/set_env_vars.sh

$ cp .env.template .env
# Edit .env and set your values
$ . ./scripts/set_env_vars.sh

GitHub connection

Create a CodeStar connection in AWS CodeSuite Console and link it to the GitHub repo so it can be used to trigger CI/CD pipelines.

The connection arn must be stored as a parameter to be used later.

Parameters

Parameters containing non-sensitive data are sotred in AWS System Manager Parameter Store. The required parameters are listed in .parameters.template.json. These parameters can be manually created from the AWS Console, or using the helper script scripts/set_parameters.py:

(.venv) $ python ./scripts/set_parameters.py .parameters.json
Settings parameters in AWS..
...  # Parameters or Errors will be printed out
Finished.

Secrets

Sensitive information is stored encrypted in AWS Secrets Manager.

The required secrets are listed in .secrets.template.json. These secrets can be manually created from the AWS Console, or using the helper script scripts/set_parameters.py with the --secret option:

(.venv) $ cp .secrets.template.json .secrets.json
# Replace the placeholders with your secret values
(.venv) $ python ./scripts/set_parameters.py --secret .secrets.json
Settings parameters in AWS..
...  # Parameters or Errors will be printed out
Finished.

Deploying

IMPORTANT: Before deploying the pipeline you need to set the secrets and parameters described above with your own values. You also need to set your own domain and SSL certificate.

Now you can deploy de CI/CD Pipeline:

$ cdk deploy MyDjangoApiPipeline

CDK will ask for confirmation before creating roles, policies and security groups. Enter 'y' for yes and the deployment process will start.You will see the deployment progress in your shell and once finished you will see the pipeline in the CodePipeline panel at the AWS Console.

After the pipeline is deployed it will be triggered and all the stacks will be created. You can monitor the stacks creation in the CloudFormation panel at the AWS Console.

This is the only time you need to run the deploy command. The next time you commit any changes in the infrastructure code, or the app code, the pipepile will update the infrastructure and will update the ecs services as needed.

License

You are free to use, copy or distribute this code. Knowledge is meant to be shared :)

THIS SOFTWARE COMES WITH NO WARRANTIES, USE AT YOUR OWN RISK

Enjoy!

About

A sample project for a scalable REST API using Django & Django REST Framework, ready to be deployed in AWS with Docker and CDK

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published