Spaces:
Sleeping
Sleeping
File size: 2,347 Bytes
832adb1 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 | # ============================================================
# Fish Speech API Server β HuggingFace Spaces Dockerfile
# Target: GPU Space (T4 or better) on HuggingFace
# Port: 7860 (required by HF Spaces)
# ============================================================
FROM nvidia/cuda:12.6.1-devel-ubuntu22.04
# HF Spaces runs containers as UID 1000
ARG USERNAME=user
ARG USER_UID=1000
ARG USER_GID=1000
ENV DEBIAN_FRONTEND=noninteractive \
PYTHONDONTWRITEBYTECODE=1 \
PYTHONUNBUFFERED=1 \
# Where the model will be downloaded at startup
MODEL_DIR=/app/models/fish-speech-1.5 \
# HF Spaces requires the app to bind to 7860
APP_PORT=7860 \
APP_BIND=0.0.0.0 \
APP_WORKERS=1
WORKDIR /app
# ββ System dependencies ββββββββββββββββββββββββββββββββββββββ
RUN apt-get update -q && \
apt-get install -fyq \
bash git cmake curl \
portaudio19-dev \
python3 python3-pip \
time && \
apt-get clean && \
rm -rf /var/lib/apt/lists/*
# ββ Python dependencies ββββββββββββββββββββββββββββββββββββββ
# Clone the repo so we get the submodule (fish_speech) too.
# We pin to main; swap for a specific commit/tag for reproducibility.
RUN git clone --recurse-submodules \
https://github.com/EvilFreelancer/docker-fish-speech-server.git \
/app
RUN pip install --no-cache-dir -r /app/requirements.txt && \
pip install --no-cache-dir "huggingface_hub[cli]"
# ββ Non-root user (required by HF Spaces) ββββββββββββββββββββ
RUN groupadd --gid ${USER_GID} ${USERNAME} && \
useradd --uid ${USER_UID} --gid ${USER_GID} -m ${USERNAME} && \
mkdir -p /app/models && \
chown -R ${USER_UID}:${USER_GID} /app
USER ${USERNAME}
# ββ Entrypoint: download model on first run, then start API ββ
# HF Spaces GPU Spaces provide CUDA at runtime via the host driver.
# The model download is deferred to startup so the Docker image
# itself stays small and HF caching can be reused across restarts.
COPY --chown=${USER_UID}:${USER_GID} entrypoint_hf.sh /app/entrypoint_hf.sh
RUN chmod +x /app/entrypoint_hf.sh
EXPOSE 7860
ENTRYPOINT ["/app/entrypoint_hf.sh"]
|