FROM python:3.11-slim as builder WORKDIR /app # Set environment variables ENV PYTHONDONTWRITEBYTECODE=1 ENV PYTHONUNBUFFERED=1 # Install system dependencies RUN apt-get update \ && apt-get install -y --no-install-recommends \ gcc \ postgresql-client \ curl \ && apt-get clean \ && rm -rf /var/lib/apt/lists/* # Install Python dependencies COPY requirements.txt . RUN pip install --no-cache-dir --upgrade pip \ && pip install --no-cache-dir -r requirements.txt # Production stage FROM python:3.11-slim WORKDIR /app # Set environment variables ENV PYTHONDONTWRITEBYTECODE=1 ENV PYTHONUNBUFFERED=1 ENV ENV=production # Create non-root user RUN groupadd -r appuser && useradd -r -g appuser appuser # Install runtime dependencies RUN apt-get update \ && apt-get install -y --no-install-recommends \ postgresql-client \ curl \ && apt-get clean \ && rm -rf /var/lib/apt/lists/* # Copy Python dependencies from builder stage COPY --from=builder /usr/local/lib/python3.11/site-packages /usr/local/lib/python3.11/site-packages COPY --from=builder /usr/local/bin /usr/local/bin # Copy project COPY . . # Change ownership to appuser RUN chown -R appuser:appuser /app # Switch to non-root user USER appuser # Health check HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \ CMD curl -f http://localhost:8000/health || exit 1 # Expose port EXPOSE 8000 # Command to run the application (production mode without reload) CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8000", "--workers", "4"]