|
|
|
FROM ghcr.io/astral-sh/uv:0.2.12 as uv |
|
|
|
|
|
FROM nvidia/cuda:12.1.1-cudnn8-devel-ubuntu22.04 |
|
|
|
ENV DEBIAN_FRONTEND=noninteractive |
|
|
|
|
|
COPY --from=uv /uv /uv |
|
|
|
|
|
RUN apt-get update && \ |
|
apt-get install -y --fix-missing --no-install-recommends \ |
|
python3.11 python3.11-venv python3-pip ffmpeg \ |
|
build-essential \ |
|
git \ |
|
&& apt-get clean && \ |
|
rm -rf /var/lib/apt/lists/* |
|
|
|
|
|
RUN --mount=type=cache,target=/root/.cache/uv \ |
|
/uv venv /opt/venv |
|
|
|
|
|
ENV VIRTUAL_ENV=/opt/venv \ |
|
PATH="/opt/venv/bin:$PATH" |
|
|
|
|
|
RUN useradd -m -u 1000 user && \ |
|
chown -R user /opt/venv |
|
|
|
|
|
USER user |
|
WORKDIR /app |
|
|
|
|
|
ENV HOME=/home/user \ |
|
PATH=/home/user/.local/bin:$PATH \ |
|
HF_HOME=/home/user/.cache/huggingface \ |
|
UV_CACHE_DIR=/app/.uv-cache |
|
|
|
|
|
RUN mkdir -p $UV_CACHE_DIR && chown -R user:user $UV_CACHE_DIR |
|
|
|
|
|
COPY --chown=user requirements.txt . |
|
|
|
|
|
RUN --mount=type=cache,target=$UV_CACHE_DIR,uid=1000,gid=1000 \ |
|
/uv pip install --no-cache-dir -r requirements.txt |
|
|
|
|
|
RUN --mount=type=cache,target=$UV_CACHE_DIR,uid=1000,gid=1000 \ |
|
/uv pip install -U --no-cache-dir setuptools wheel ninja packaging |
|
|
|
|
|
RUN --mount=type=cache,target=$UV_CACHE_DIR,uid=1000,gid=1000 \ |
|
/uv pip install flash-attn --no-build-isolation |
|
|
|
|
|
|
|
COPY --chown=user . . |
|
|
|
|
|
EXPOSE 7860 |
|
|
|
|
|
CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "7860"] |