Spaces:
Sleeping
Sleeping
| # Use an official Python runtime as a parent image | |
| FROM python:3.9-slim | |
| # Set the working directory | |
| WORKDIR /app | |
| # Install necessary system dependencies | |
| RUN apt-get update && apt-get install -y gcc && rm -rf /var/lib/apt/lists/* | |
| # Set the CC environment variable to ensure TorchInductor uses the correct compiler | |
| ENV CC=gcc | |
| # Copy the requirements file and install dependencies | |
| COPY requirements.txt . | |
| RUN pip install --no-cache-dir -r requirements.txt | |
| # Create cache and config directories with appropriate permissions | |
| RUN mkdir -p /app/cache && chmod 777 /app/cache | |
| RUN mkdir -p /app/config && chmod 777 /app/config | |
| RUN mkdir -p /app/triton_cache && chmod 777 /app/triton_cache | |
| RUN mkdir -p /app/torchinductor_cache && chmod 777 /app/torchinductor_cache | |
| # Set environment variables for Hugging Face cache, config, Triton, and TorchInductor directories | |
| ENV HF_HOME=/app/cache | |
| ENV XDG_CONFIG_HOME=/app/config | |
| ENV TRITON_CACHE_DIR=/app/triton_cache | |
| ENV TORCHINDUCTOR_CACHE_DIR=/app/torchinductor_cache | |
| # Copy the application code | |
| COPY main.py . | |
| # Expose the port FastAPI will run on | |
| EXPOSE 7860 | |
| # Command to run the FastAPI app | |
| CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "7860"] | |