Spaces:
Running
Running
File size: 1,643 Bytes
86fe272 80dadd4 86fe272 393e4b8 2cfc1c6 393e4b8 80dadd4 393e4b8 80dadd4 63fbcb1 2cfc1c6 63fbcb1 2cfc1c6 80dadd4 77bf495 44fb940 393e4b8 63fbcb1 393e4b8 80dadd4 77bf495 80dadd4 393e4b8 335bfb5 2d6bf75 fca48a0 |
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 |
FROM python:3.11-slim-bullseye
# Allow statements and log messages to immediately appear in the Knative logs
ENV PYTHONUNBUFFERED True
# Adds GCC and other build tools so we can compile hnswlib and other native/C++ deps.
RUN apt-get update --fix-missing && apt-get install -y --fix-missing build-essential && \
rm -rf /var/lib/apt/lists/*
# See: https://huggingface.co/docs/hub/spaces-sdks-docker#permissions
RUN useradd -m -u 1000 user
USER user
ENV HOME=/home/user \
PATH=/home/user/.local/bin:$PATH
# Set the working directory in the container.
WORKDIR $HOME/app
# Install the dependencies. This will look in ./dist for any wheels that match lilac. If they are
# not found, it will use the public pip package.
# Pip install lilac[all] and dependencies before trying to install the local image. This allows us
# to get cache hits on dependency installations when using a local wheel. When using the public pip
# package, the second call will be a no-op.
RUN python -m pip install lilac[all]
# Install from the local wheel inside ./dist. This will be a no-op if the wheel is not found.
COPY --chown=user /dist ./dist/
RUN python -m pip install --find-links=dist --upgrade lilac[all]
# Install the huggingface hub, used to download files.
RUN pip install huggingface_hub
# Copy the README so we can read the datasets from the HuggingFace config.
COPY --chown=user README.md .
# Copy the license just in case.
COPY --chown=user LICENSE .
COPY --chown=user docker_start.sh ./
# Make a local data directory for non-persistent storage demos.
RUN mkdir -p ./data
RUN chown -R user ./data
EXPOSE 5432
CMD ["bash", "docker_start.sh"]
|