64 lines
3.7 KiB
Docker
64 lines
3.7 KiB
Docker
# ==========================================
|
||
# Dockerfile для Django + Gunicorn + WhiteNoise
|
||
# ==========================================
|
||
|
||
# 1. Базовый образ: Python 3.12 (Slim версия для меньшего размера)
|
||
FROM python:3.12-slim
|
||
|
||
# 2. Переменные окружения для Python
|
||
# PYTHONDONTWRITEBYTECODE: Запрещает Python писать .pyc файлы
|
||
# PYTHONUNBUFFERED: Гарантирует, что вывод консоли (logs) виден сразу (не буферизуется)
|
||
ENV PYTHONDONTWRITEBYTECODE=1
|
||
ENV PYTHONUNBUFFERED=1
|
||
# Poetry настройки: не создавать виртуальное окружение внутри контейнера (ставим системно).
|
||
# Дублирует `poetry config virtualenvs.create false` в пп.7 (на всякий случай).
|
||
ENV POETRY_VIRTUALENVS_CREATE=false
|
||
# Путь настройки Django (по умолчанию для production) на случай если контейнер будет запущен не через docker-compose.
|
||
ENV DJANGO_SETTINGS_MODULE=dicquo.settings
|
||
|
||
# 3. Рабочая директория внутри контейнера
|
||
WORKDIR /app
|
||
|
||
# 4. Установка системных зависимостей
|
||
# - libjpeg-dev zlib1g-dev: библиотеки для работы с изображениями (Pillow)
|
||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||
libjpeg-dev \
|
||
zlib1g-dev \
|
||
&& rm -rf /var/lib/apt/lists/*
|
||
|
||
# 5. Установка Poetry через pip (быстро и надежно)
|
||
RUN pip install --no-cache-dir poetry
|
||
|
||
# 6. Копируем файлы зависимостей (pyproject.toml и poetry.lock)
|
||
# Делаем это ДО копирования всего кода, чтобы использовать кэш Docker layers.
|
||
COPY pyproject.toml poetry.lock /app/
|
||
|
||
# 7. Установка зависимостей проекта
|
||
# --no-interaction: не будет спрашивать подтверждения
|
||
# --no-ansi: уберваем цветные символы из логов сборки (они иногда мусорят)
|
||
# --no-root: не устанавливать сам проект как пакет (мы просто копируем код)
|
||
# --only main: не ставить dev-зависимости (тесты, линтеры и т.п.) для продакшена
|
||
# RUN poetry install --no-root --only main
|
||
# Настройка Poetry: не создавать venv и установка зависимостей (без dev-зависимостей для продакшена)
|
||
RUN poetry config virtualenvs.create false \
|
||
&& poetry install --no-interaction --no-ansi --no-root --only main
|
||
|
||
# 8. Копируем весь исходный код проекта в контейнер
|
||
COPY . /app/
|
||
|
||
# 9. Сборка статики (CSS, JS)
|
||
# Важно: Запускаем collectstatic с фейковым SECRET_KEY, так как на этапе сборки env файла может не быть.
|
||
RUN SECRET_KEY=dummy_build_key python dicquo/manage.py collectstatic --noinput --clear
|
||
|
||
# 10. Открываем порт 8000
|
||
EXPOSE 8000
|
||
|
||
# 11. Команда запуска
|
||
# Переходим в подпапку dicquo, где лежит код Django проекта
|
||
WORKDIR /app/dicquo
|
||
|
||
# Запускаем Gunicorn (по умолчанию, если не переопределено в docker-compose) на три воркера, привязывая его к
|
||
# порту 8000 и указывая на точку входа приложения (wsgi.py).
|
||
CMD ["gunicorn", "--workers", "3", "--bind", "0.0.0.0:8000", "dicquo.wsgi:application"]
|
||
|