add: вся для запуска в docker

This commit is contained in:
2026-02-20 13:09:00 +03:00
parent 7c62b49396
commit b95fb628b1
4 changed files with 277 additions and 0 deletions

61
docker-compose.yml Normal file
View File

@@ -0,0 +1,61 @@
# ==============================================================================
# Docker Compose для РАЗРАБОТКИ (Local Development)
# Этот файл содержит настройки для локальной работы (live reload, debug).
# Запуск: docker compose up --build
# ==============================================================================
services:
web:
# Имя контейнера для удобства
container_name: dq_app_dev
# Сборка из текущей директории
build: .
# Проброс портов (чтобы сайт был доступен на localhost:8000)
ports:
- "8000:8000"
# 1. КОМАНДА ЗАПУСКА (Dev режим)
# Используем --reload для авто-перезагрузки при изменении кода.
# Уменьшаем число воркеров до 2 (экономия ресурсов dev-машины).
# Убираем collectstatic (в dev Django сам может отдавать статику или она нам не так важна сжатой)
# Но миграции оставляем, чтобы база была актуальной.
command: >
sh -c "python manage.py migrate --noinput &&
gunicorn --workers 2 --bind 0.0.0.0:8000 --reload dicquo.wsgi:application"
# 2. МОНТИРОВАНИЕ КОДА (Live Reload)
# Подключаем локальные папки внутрь контейнера, чтобы Gunicorn видел изменения без пересборки образа.
volumes:
# Монтируем основной код проекта.
# Так как web, templates и manage.py лежат внутри dicquo/, одного этого маунта достаточно.
- ./dicquo:/app/dicquo
# Монтируем всю папку public (Static + Media)
# Это нужно, чтобы:
# 1. Изменения в CSS/JS (public/static) сразу были видны (Live Reload).
# 2. Загруженные картинки (public/media) сохранялись на диске.
- ./public:/app/public
# Монтируем базу данных (чтобы данные сохранялись при пересоздании контейнера)
# Используем ту же папку database, что и на проде, для единообразия.
# ВАЖНО: Django ищет базу в BASE_DIR.parent / 'database/db.sqlite3'
# В контейнере BASE_DIR=/app/dicquo, значит путь к базе: /app/database/db.sqlite3
- ./database:/app/database
# 3. ПЕРЕМЕННЫЕ ОКРУЖЕНИЯ
environment:
- DEBUG=True
- DJANGO_LOG_LEVEL=DEBUG
# В dev нам не нужно ограничивать буферизацию так строго, но не помешает.
# 4. РЕСУРСЫ (Без лимитов)
# Удаляем секцию ограничений, чтобы локально использовать все доступные ресурсы хоста.
# deploy:
# resources:
# limits:
# cpus: ...
# memory: ...
# mem_limit: ...