Skip to content

Latest commit

 

History

History
105 lines (77 loc) · 2.54 KB

README.md

File metadata and controls

105 lines (77 loc) · 2.54 KB

Django Blog project

Project features:

  • Docker/Docker-compose environment
  • Environment variables
  • Separated settings for Dev and Prod django version
  • Docker configuration for nginx for 80 and/or 443 ports (dev/stage/prod) (Let's Encrypt certbot)
  • Celery worker
  • Redis service for caching using socket. Also message broker for queue
  • RabbitMQ configuration
  • ASGI support
  • Linters integration (flake8, black, isort)
  • Swagger in Django Admin Panel
  • Ready for deploy by one click
  • Separated configuration for dev and prod (requirements and settings)
  • CI/CD: GitHub Actions
  • Redefined default User model (main.models.py)
  • Mailpit, Jaeger, RabbitMQ integrations
  • Multi-stage build for prod versions
  • PostgreSql Backup

How to use:

Clone the repo or click "Use this template" button:

git clone https://github.com/bandirom/django-blog.git

Before running add your superuser email/password and project name in docker/prod/env/.data.env file

SUPERUSER_EMAIL=[email protected]
SUPERUSER_PASSWORD=secretp@ssword
PROJECT_TITLE=MyProject

Run the local develop server:

docker-compose up -d --build
docker-compose logs -f
Server will run on 8008 port. You can get access to server by browser http://localhost:8008

Run django commands through exec:

docker-compose exec web python manage.py makemigrations

docker-compose exec web python manage.py shell

Get access to the container

docker-compose exec web sh
For run mail smtp for local development you can use Mailpit service
  • Run Mailpit
docker run -p 1025:1025 -p 8025:8025 -d -it --rm axllent/mailpit

Don't forget to set SMTP mail backend in settings

# docker/dev/env/.email.env
EMAIL_HOST=<mailpit_hostname>

Where <mailpit_hostname>:

  • host.docker.internal for Window and macOS
  • 172.17.0.1 for Linux OS

Production environment

If your server under LoadBalancer or nginx with SSL/TLS certificate you can run prod.yml configuration

docker-compose -f prod.yml up -d --build

For set https connection you should have a domain name

In prod.certbot.yml:

Change the envs: CERTBOT_EMAIL: your real email ENVSUBST_VARS: list of variables which set in nginx.conf files APP: value of the variable from list ENVSUBST_VARS

To set https for 2 and more nginx servers:

ENVSUBST_VARS: API
API: api.your-domain.com

Run command:

docker-compose -f prod.yml -f prod.certbot.yml up -d --build