FROM python:3.10-slim | |
WORKDIR /app | |
# Install system dependencies including build tools for LoRA compilation | |
RUN apt-get update && apt-get install -y \ | |
curl \ | |
git \ | |
build-essential \ | |
gcc \ | |
g++ \ | |
cmake \ | |
ninja-build \ | |
pkg-config \ | |
&& rm -rf /var/lib/apt/lists/* | |
# Set C compiler environment variable | |
ENV CC=gcc | |
ENV CXX=g++ | |
# Copy requirements first for better caching | |
COPY requirements.txt . | |
RUN pip install --no-cache-dir -r requirements.txt | |
# Copy application code | |
COPY . . | |
# Expose port | |
EXPOSE 7860 | |
# Health check | |
HEALTHCHECK --interval=30s --timeout=30s --start-period=120s --retries=3 \ | |
CMD curl -f http://localhost:7860/health || exit 1 | |
# Run the application | |
CMD ["uvicorn", "app:app", "--host", "0.0.0.0", "--port", "7860"] |