FROM nvidia/cuda:12.1.0-base-ubuntu22.04 # Install Python and other dependencies RUN apt-get update && apt-get install -y --no-install-recommends \ python3.10 \ python3.10-venv \ espeak-ng \ git \ libsndfile1 \ curl \ && apt-get clean \ && rm -rf /var/lib/apt/lists/* # Install uv COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/ # Create non-root user RUN useradd -m -u 1000 appuser # Create directories and set ownership RUN mkdir -p /app/api/model_files && \ mkdir -p /app/api/src/voices && \ chown -R appuser:appuser /app USER appuser # Download and extract models WORKDIR /app/api/model_files RUN curl -L -o model.tar.gz https://github.com/remsky/Kokoro-FastAPI/releases/download/v0.0.1/kokoro-82m-pytorch.tar.gz && \ tar xzf model.tar.gz && \ rm model.tar.gz # Download and extract voice models WORKDIR /app/api/src/voices RUN curl -L -o voices.tar.gz https://github.com/remsky/Kokoro-FastAPI/releases/download/v0.0.1/voice-models.tar.gz && \ tar xzf voices.tar.gz && \ rm voices.tar.gz # Switch back to app directory WORKDIR /app # Copy dependency files COPY --chown=appuser:appuser pyproject.toml ./pyproject.toml # Install dependencies RUN --mount=type=cache,target=/root/.cache/uv \ uv venv && \ uv sync --extra gpu --no-install-project # Copy project files COPY --chown=appuser:appuser api ./api # Install project RUN --mount=type=cache,target=/root/.cache/uv \ uv sync --extra gpu # Set environment variables ENV PYTHONUNBUFFERED=1 ENV PYTHONPATH=/app:/app/Kokoro-82M ENV PATH="/app/.venv/bin:$PATH" ENV UV_LINK_MODE=copy # Run FastAPI server CMD ["uv", "run", "python", "-m", "uvicorn", "api.src.main:app", "--host", "0.0.0.0", "--port", "8880", "--log-level", "debug"]