kamyvision-api / Dockerfile
oyabun-dev's picture
deploy: 2026-03-30T04:25:24Z
0af0f05
raw
history blame contribute delete
929 Bytes
FROM python:3.11-slim
RUN apt-get update && apt-get install -y \
ffmpeg \
libgl1 \
libglib2.0-0 \
libsm6 \
libxext6 \
libxrender-dev \
curl \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /app
COPY requirements.txt .
# Install torch CPU-only first (~250MB vs ~2GB for the default CUDA build)
RUN \
pip install torch torchvision --index-url https://download.pytorch.org/whl/cpu
RUN \
pip install --timeout 300 -r requirements.txt
COPY app/ ./app/
COPY scripts/ ./scripts/
EXPOSE 8000
HEALTHCHECK --interval=30s --timeout=10s --start-period=300s --retries=3 \
CMD curl -f http://localhost:8000/health || exit 1
# Models download on first cold start and are cached by HF Spaces persistently.
# preload_models.py runs before uvicorn so the API is ready when /health passes.
CMD ["sh", "-c", "python scripts/preload_models.py && uvicorn app.main:app --host 0.0.0.0 --port 8000 --workers 1"]