FROM python:3.12-slim AS builder ENV PYTHONDONTWRITEBYTECODE=1 \ PYTHONUNBUFFERED=1 \ PIP_NO_CACHE_DIR=1 \ VIRTUAL_ENV=/opt/venv WORKDIR /app RUN apt-get update \ && apt-get install -y --no-install-recommends build-essential libpq-dev \ && rm -rf /var/lib/apt/lists/* RUN python -m venv "${VIRTUAL_ENV}" ENV PATH="${VIRTUAL_ENV}/bin:${PATH}" COPY requirements/base.txt /tmp/requirements/base.txt RUN pip install --upgrade pip && pip install -r /tmp/requirements/base.txt FROM python:3.12-slim AS runtime ENV PYTHONDONTWRITEBYTECODE=1 \ PYTHONUNBUFFERED=1 \ PIP_NO_CACHE_DIR=1 \ VIRTUAL_ENV=/opt/venv \ PATH="/opt/venv/bin:/home/app/.local/bin:${PATH}" \ APP_USER=app \ APP_UID=10001 \ APP_GID=10001 WORKDIR /app RUN apt-get update \ && apt-get install -y --no-install-recommends libpq5 postgresql-client curl \ && rm -rf /var/lib/apt/lists/* RUN groupadd --gid "${APP_GID}" "${APP_USER}" \ && useradd --uid "${APP_UID}" --gid "${APP_GID}" --create-home --shell /usr/sbin/nologin "${APP_USER}" COPY --from=builder /opt/venv /opt/venv COPY . /app RUN chmod +x /app/entrypoint.sh \ && mkdir -p /app/staticfiles /app/media /app/snapshots/incoming /app/snapshots/archive /app/snapshots/failed \ && chown -R "${APP_UID}:${APP_GID}" /app /opt/venv USER ${APP_UID}:${APP_GID} ENTRYPOINT ["/app/entrypoint.sh"] CMD ["gunicorn", "config.wsgi:application", "--bind", "0.0.0.0:8000", "--workers", "3", "--access-logfile", "-", "--error-logfile", "-"]