124-webapp/Dockerfile
2025-10-07 13:02:29 +02:00

43 lines
1.3 KiB
Docker

# --- Base image ---
FROM python:3.12-slim
# --- Environment variables ---
ENV PYTHONDONTWRITEBYTECODE=1
ENV PYTHONUNBUFFERED=1
# --- Set working directory ---
WORKDIR /cost-assistant
# --- Install system dependencies (cached until packages change) ---
RUN apt-get update && apt-get install -y --no-install-recommends \
libgl1 \
libglib2.0-0 \
poppler-utils \
curl \
&& rm -rf /var/lib/apt/lists/*
# --- Install Python dependencies (cached until requirements.txt changes) ---
COPY requirements.txt .
RUN python -m pip install --no-cache-dir -r requirements.txt
# --- Create user early (cached, rarely changes) ---
RUN groupadd -r appuser && useradd -r -g appuser appuser
# --- Copy only necessary application files ---
COPY --chown=appuser:appuser main.py .
COPY --chown=appuser:appuser cost_calculator.py .
COPY --chown=appuser:appuser mailer.py .
COPY --chown=appuser:appuser templates/ ./templates/
COPY --chown=appuser:appuser static/ ./static/
# --- Create upload folder ---
RUN mkdir -p data/uploads && chown -R appuser:appuser data/uploads
# --- Switch to non-root user for security ---
USER appuser
# --- Expose internal port ---
EXPOSE 8000
# --- Run Gunicorn with Uvicorn worker for production ---
CMD ["gunicorn", "main:app", "-k", "uvicorn.workers.UvicornWorker", "--bind", "0.0.0.0:8000", "--workers", "4", "--timeout", "120"]