Some checks failed
CI/CD Pipeline / Start Dev Containers in Dokploy (push) Has been skipped
CI/CD Pipeline / Start Dev Containers in Dokploy (pull_request) Has been skipped
CI/CD Pipeline / Quality Gate (pull_request) Failing after 2m47s
CI/CD Pipeline / Build and Push Images (pull_request) Has been skipped
CI/CD Pipeline / Quality Gate (push) Successful in 3m14s
CI/CD Pipeline / Build and Push Images (push) Has been skipped
CI/CD Pipeline / Internal Notify (pull_request) Successful in 1s
CI/CD Pipeline / Internal Notify (push) Successful in 1s
137 lines
3.2 KiB
Docker
137 lines
3.2 KiB
Docker
FROM python:3.11-slim-bookworm AS base
|
|
|
|
ENV PYTHONDONTWRITEBYTECODE=1 \
|
|
PYTHONUNBUFFERED=1 \
|
|
UV_COMPILE_BYTECODE=1 \
|
|
UV_LINK_MODE=copy \
|
|
UV_PYTHON_DOWNLOADS=never \
|
|
UV_PROJECT_ENVIRONMENT=/app/.venv
|
|
|
|
WORKDIR /app
|
|
|
|
RUN groupadd -r appgroup && useradd -r -g appgroup -m appuser
|
|
|
|
# Install uv binary.
|
|
COPY --from=ghcr.io/astral-sh/uv:0.7.2 /uv /uvx /usr/local/bin/
|
|
|
|
|
|
FROM base AS builder
|
|
|
|
ARG INSTALL_DEV=false
|
|
|
|
# hadolint ignore=DL3008
|
|
RUN apt-get update \
|
|
&& apt-get install -y --no-install-recommends \
|
|
build-essential \
|
|
gcc \
|
|
libpq-dev \
|
|
libffi-dev \
|
|
libxml2-dev \
|
|
libxslt1-dev \
|
|
zlib1g-dev \
|
|
pkg-config \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
COPY pyproject.toml uv.lock ./
|
|
|
|
RUN if [ "${INSTALL_DEV}" = "true" ]; then \
|
|
uv sync --frozen --no-install-project --dev; \
|
|
else \
|
|
uv sync --frozen --no-install-project; \
|
|
fi
|
|
|
|
|
|
FROM base AS runtime-base
|
|
|
|
# hadolint ignore=DL3008
|
|
RUN apt-get update \
|
|
&& apt-get install -y --no-install-recommends \
|
|
curl \
|
|
libpq5 \
|
|
libffi8 \
|
|
libxml2 \
|
|
libxslt1.1 \
|
|
zlib1g \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
COPY --from=builder /app/.venv /app/.venv
|
|
COPY src/ ./src/
|
|
COPY docker/scripts/ ./docker/scripts/
|
|
|
|
RUN mkdir -p logs media staticfiles input/fns input/fns/processed input/fns/failed src/static \
|
|
&& chmod +x /app/docker/scripts/*.sh \
|
|
&& chown -R appuser:appgroup /app
|
|
|
|
ENV PATH="/app/.venv/bin:${PATH}" \
|
|
PYTHONPATH=/app/src \
|
|
DJANGO_SETTINGS_MODULE=settings.dev \
|
|
POSTGRES_HOST=10.10.0.114 \
|
|
POSTGRES_PORT=5432 \
|
|
POSTGRES_DB=mostovik \
|
|
POSTGRES_USER=postgres \
|
|
POSTGRES_PASSWORD=postgres \
|
|
POSTGRES_SSLMODE=disable \
|
|
REDIS_HOST=10.10.0.110 \
|
|
REDIS_CACHE_URL=redis://10.10.0.110:6379/1 \
|
|
CELERY_BROKER_URL=redis://10.10.0.110:6379/0 \
|
|
CELERY_RESULT_BACKEND=redis://10.10.0.110:6379/0 \
|
|
PORT=8000 \
|
|
GUNICORN_WORKERS=4 \
|
|
GUNICORN_TIMEOUT=60 \
|
|
CELERY_LOG_LEVEL=INFO \
|
|
CELERY_WORKER_CONCURRENCY=2 \
|
|
CHECKO_API_KEY=pRiEnJuD1tclsLCb \
|
|
ZAKUPKI_TOKEN=019c03d7-e1f6-7091-b296-8c88b4c585dd \
|
|
COLLECTSTATIC_ON_MIGRATE=0 \
|
|
BACKUP_ENCRYPTION_KEY=a2tra2tra2tra2tra2tra2tra2tra2tra2tra2s \
|
|
BACKUP_KEY_ID=default \
|
|
BACKUP_EXPORT_DIRECTORY=/app/media/backups \
|
|
STATE_CORP_EXCHANGE_URL= \
|
|
STATE_CORP_EXCHANGE_TOKEN= \
|
|
STATE_CORP_EXCHANGE_KEY_ID=state-corp-shared-token \
|
|
STATE_CORP_EXCHANGE_TIMEOUT_SECONDS=60
|
|
|
|
USER appuser
|
|
|
|
|
|
FROM runtime-base AS runtime-web
|
|
|
|
EXPOSE 8000
|
|
CMD ["/app/docker/scripts/start-web.sh"]
|
|
|
|
|
|
FROM runtime-base AS runtime-celery
|
|
|
|
USER root
|
|
|
|
# Playwright/Chromium runtime dependencies.
|
|
# hadolint ignore=DL3008
|
|
RUN apt-get update \
|
|
&& apt-get install -y --no-install-recommends \
|
|
libnss3 \
|
|
libnspr4 \
|
|
libatk1.0-0 \
|
|
libatk-bridge2.0-0 \
|
|
libcups2 \
|
|
libdrm2 \
|
|
libdbus-1-3 \
|
|
libxkbcommon0 \
|
|
libxcomposite1 \
|
|
libxdamage1 \
|
|
libxfixes3 \
|
|
libxrandr2 \
|
|
libgbm1 \
|
|
libasound2 \
|
|
libpango-1.0-0 \
|
|
libcairo2 \
|
|
libatspi2.0-0 \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
ENV PLAYWRIGHT_BROWSERS_PATH=/app/.playwright
|
|
RUN python -m playwright install chromium \
|
|
&& chown -R appuser:appgroup /app
|
|
|
|
USER appuser
|
|
|
|
CMD ["/app/docker/scripts/start-celery-worker.sh"]
|