From f477346f1e906b647f56a9a145ef0044645ac9d1 Mon Sep 17 00:00:00 2001 From: imperosol Date: Sun, 1 Dec 2024 16:24:34 +0100 Subject: [PATCH] allow redis and postgres to run in docker compose --- core/management/commands/setup.py | 3 ++- docker-compose.yml | 36 +++++++++++++++++++++++++++++++ 2 files changed, 38 insertions(+), 1 deletion(-) create mode 100644 docker-compose.yml diff --git a/core/management/commands/setup.py b/core/management/commands/setup.py index 37451dd3..297296e0 100644 --- a/core/management/commands/setup.py +++ b/core/management/commands/setup.py @@ -16,6 +16,7 @@ from django.conf import settings from django.core.management import call_command from django.core.management.base import BaseCommand +from django.db import connection class Command(BaseCommand): @@ -29,7 +30,7 @@ class Command(BaseCommand): if not data_dir.is_dir(): data_dir.mkdir() db_path = settings.BASE_DIR / "db.sqlite3" - if db_path.exists(): + if db_path.exists() or connection.vendor != "sqlite": call_command("flush", "--noinput") self.stdout.write("Existing database reset") call_command("migrate") diff --git a/docker-compose.yml b/docker-compose.yml new file mode 100644 index 00000000..d83226a9 --- /dev/null +++ b/docker-compose.yml @@ -0,0 +1,36 @@ +services: + db: + image: postgres:16.6 + restart: unless-stopped + deploy: + resources: + limits: + cpus: '0.5' + memory: 512M + ports: + - "5431:5432" + environment: + POSTGRES_USER: sith + POSTGRES_PASSWORD: sith + POSTGRES_DB: sith + + redis: + image: redis:latest + restart: unless-stopped + deploy: + resources: + limits: + cpus: '0.5' + memory: 512M + ports: + - "6378:6379" + command: redis-server + volumes: + - redis_data:/var/lib/redis/data/ + +volumes: + postgres_data: + driver: local + redis_data: + driver: local +