Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mukulmantosh/pulumi_django
Managing AWS Resources from Django Admin using Pulumi
https://github.com/mukulmantosh/pulumi_django
aws django iaac infrastructure-as-code pulumi pulumi-aws python3
Last synced: 13 days ago
JSON representation
Managing AWS Resources from Django Admin using Pulumi
- Host: GitHub
- URL: https://github.com/mukulmantosh/pulumi_django
- Owner: mukulmantosh
- Created: 2023-01-28T12:17:52.000Z (about 2 years ago)
- Default Branch: master
- Last Pushed: 2023-02-19T05:52:41.000Z (about 2 years ago)
- Last Synced: 2025-02-06T19:32:13.963Z (14 days ago)
- Topics: aws, django, iaac, infrastructure-as-code, pulumi, pulumi-aws, python3
- Language: Python
- Homepage:
- Size: 1.24 MB
- Stars: 4
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# IaaC using Django & Pulumi
data:image/s3,"s3://crabby-images/36f3f/36f3f23d4b8b1c5eb5319b23451b8702e4100f34" alt="stack_logo"
## Prerequisites
Before starting up this project, make sure you have an AWS account.
### Software Installation
- [x] [AWS Command Line Interface](https://aws.amazon.com/cli/) - The AWS Command Line Interface (CLI) is a unified tool to manage your AWS services.
- [x] [Pulumi](https://www.pulumi.com/) - Universal Infrastructure as Code
## Python Dependencies
- Installing Python Packages
```bash
$ pip install -r requirements.txt
```
* Note: For our project we are using **db.sqlite3**. I strongly recommend to use Postgres/MySQL when setting up in production.
## Pulumi Stack
Login to Pulumi and create a new project.
Make sure to name the stack as **aws-python**.
data:image/s3,"s3://crabby-images/8f7c7/8f7c7bbfb3a5e431d6f1bd7ac65ac96bc03d6526" alt="step1"
Update the respective YAML files & django settings in the codebase.
**Pulumi.yaml**
data:image/s3,"s3://crabby-images/7b2d4/7b2d4d738fe5f917979656316ef2fcb88c277bb7" alt="step2"
**settings.py**
data:image/s3,"s3://crabby-images/482a4/482a4aad3d18c9e6948b6a254057c825bdd93c27" alt="step3"
## Pulumi CLI
Run the below command :
- **pulumi login**data:image/s3,"s3://crabby-images/72d03/72d03077eea90b41b4721094abacaed76a07505c" alt="step4"
## Migrating Tables
Run the below command :
- **python manage.py migrate**
data:image/s3,"s3://crabby-images/04241/04241c5622d08ade013d07162d5d1b9201cfaeef" alt="step5"
## Creating SuperUser
Run the below command :
- **python manage.py createsuperuser**
data:image/s3,"s3://crabby-images/fd105/fd105a59e3283a5eeec70747b439d7283795cd6a" alt="step6"
## AWS Credentials
Make sure to update your AWS credentials, residing in **$HOME/.aws/credentials**
* Note: For this demo, make sure the IAM User should have **AdministratorAccess**. This is not **recommended** permission you need to give. Kindly, follow the security best practices.
```
[default]
aws_access_key_id = xxxxxxxxxxxxxxxxxxxxx
aws_secret_access_key = xxxxxxxxxxxxxxxxxxxxxxx
```## Loading AWS Resources
Run the below command :
- **python manage.py load_resources**
This command is going to dump all the AWS resources into your database.
- VPC
- Subnets
- Security Groups
- Key Pair
- Instance Typesdata:image/s3,"s3://crabby-images/3525b/3525bc4cacccd8a8faad6a663ccc1f3689423a28" alt="step7"
## Logging into Django Admin
Provide the superuser credentials, which you have created recently.
data:image/s3,"s3://crabby-images/8c043/8c043107b7298f8f40eec4588659ca538a0e5f93" alt="step8"
data:image/s3,"s3://crabby-images/830e7/830e79bb468342c7cbd502e51224c7fd885788c4" alt="step9"
You can now observe that all the AWS information has been dumped in our database, and it's reflected in the admin.
### Instance Typesdata:image/s3,"s3://crabby-images/ae41c/ae41cd64f3ee474a889ea07dade5e66ddfa31e65" alt="step10"
### Operating Systems
data:image/s3,"s3://crabby-images/6ed41/6ed41fea5ad9393fe88bec18282cd88314664a79" alt="step11"
## Creating an EC2 Instance
We will provide all the necessary information for creating EC2 Instance.
* Note: Pulumi will be invoked in the foreground, I recommend using background tasks like Celery & RabbitMQ
data:image/s3,"s3://crabby-images/c6fb5/c6fb5631bbddc3f055d7d25c45f2325e41b033af" alt="step12"
You can see below, that the instance has been created and the Public IPv4 address has been updated.
data:image/s3,"s3://crabby-images/d7a40/d7a40a09319e110a5837e62b1b6b6b05c52d7899" alt="step13"
data:image/s3,"s3://crabby-images/9c67d/9c67da986acbbe3c8623ecae8ae37c9ed0fc7144" alt="step14"
## Deleting an EC2 Instance
Now, we will go ahead and delete the instance information from Django Admin
data:image/s3,"s3://crabby-images/13640/1364056cd9448778cbdf7fec1b250cc4a60e5a8c" alt="step15"
You can observe the django console, that Pulumi has started the process to terminate the instance.
data:image/s3,"s3://crabby-images/15df4/15df49e63a545d5d64f4172442edeada75036746" alt="step16"
data:image/s3,"s3://crabby-images/909ba/909ba339f43bb85c2875e914c2b2b33e203a6720" alt="step17"
## References
If you are interested to know more about Pulumi.
- [How to use Pulumi YAML](https://www.pulumi.com/docs/intro/languages/yaml/)
- [Pulumi Automation API](https://www.pulumi.com/automation/)