smhs16's picture
Upload 9 files
ac01a7a verified
# Multi-stage build — keeps final image small and dependency-free from build tools
# ── Stage 1: Build ────────────────────────────────────────────────────────────
FROM python:3.11-slim AS builder
WORKDIR /app
COPY requirements.txt .
RUN pip install --no-cache-dir --user -r requirements.txt
# ── Stage 2: Runtime ──────────────────────────────────────────────────────────
FROM python:3.11-slim
WORKDIR /app
# Non-root user for security
RUN useradd -m -u 1001 appuser
# Copy installed packages from builder
COPY --from=builder /root/.local /home/appuser/.local
# Copy application source
COPY --chown=appuser:appuser . .
# Create writable dirs the app needs
RUN mkdir -p models data/raw data/processed reports metrics \
&& chown -R appuser:appuser models data reports metrics
USER appuser
ENV PATH=/home/appuser/.local/bin:$PATH \
PYTHONUNBUFFERED=1 \
PYTHONDONTWRITEBYTECODE=1
EXPOSE 8000
HEALTHCHECK --interval=30s --timeout=10s --start-period=15s --retries=3 \
CMD python -c "import urllib.request; urllib.request.urlopen('http://localhost:8000/health')"
CMD ["uvicorn", "api.main:app", "--host", "0.0.0.0", "--port", "8000", "--workers", "2"]