fastwhisper_api / Dockerfile
sidmazak's picture
Update Dockerfile
e23ba61 verified
FROM python:3.10-slim-bookworm AS builder
# Install system dependencies for compiling audio tools and Python packages
RUN apt-get update && apt-get install -y --no-install-recommends \
gcc \
g++ \
ffmpeg \
libsndfile1 \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /app
# Copy requirements first for better caching
COPY requirements.txt .
# Install Python dependencies.
# Ensure we use a CPU-only version of PyTorch to avoid CUDA bloat.
# If your requirements.txt already pulls torch without CUDA, you can keep the simple install.
RUN pip install --no-cache-dir --upgrade pip && \
pip install --no-cache-dir -r requirements.txt \
--extra-index-url https://download.pytorch.org/whl/cpu
# Final stage
FROM python:3.10-slim-bookworm
# Install runtime system dependencies
RUN apt-get update && apt-get install -y --no-install-recommends \
ffmpeg \
libsndfile1 \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /app
# Copy installed packages from builder
COPY --from=builder /usr/local/lib/python3.10/site-packages /usr/local/lib/python3.10/site-packages
COPY --from=builder /usr/local/bin /usr/local/bin
# Copy application code
COPY app.py .
# Create non-root user for security
RUN useradd -m -u 1000 appuser && chown -R appuser:appuser /app
USER appuser
# Environment variables with defaults
ENV MODEL_SIZE=small \
MAX_FILE_SIZE_MB=200 \
LOG_LEVEL=INFO \
PORT=7860
# Health check
HEALTHCHECK --interval=30s --timeout=10s --start-period=60s --retries=3 \
CMD curl -f http://localhost:7860/health || exit 1
EXPOSE 7860
CMD ["uvicorn", "app:app", "--host", "0.0.0.0", "--port", "7860"]