Spaces:
Running
Running
FROM python:3.11-slim | |
# Install system dependencies with security updates | |
RUN apt-get update && apt-get install -y \ | |
curl \ | |
&& apt-get upgrade -y \ | |
&& apt-get clean \ | |
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* | |
# Create non-root user for security | |
RUN groupadd -r appuser && useradd -r -g appuser -m appuser | |
# Set working directory | |
WORKDIR /app | |
# Copy requirements and install Python packages | |
COPY requirements.txt . | |
RUN pip3 install --no-cache-dir --upgrade pip && \ | |
pip3 install --no-cache-dir -r requirements.txt | |
# Copy FastAPI application | |
COPY app.py . | |
# Create logs directory and change ownership | |
RUN mkdir -p /app/logs && \ | |
chown -R appuser:appuser /app | |
# Set environment variables | |
ENV HOME=/home/appuser | |
# Switch to non-root user | |
USER appuser | |
# Expose port | |
EXPOSE 7860 | |
# Health check | |
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \ | |
CMD curl -f http://localhost:7860/health || exit 1 | |
# Start FastAPI application | |
CMD ["python3", "-m", "uvicorn", "app:app", "--host", "0.0.0.0", "--port", "7860"] |