File size: 3,678 Bytes
2625c97 833b90f 331bf2d 833b90f 331bf2d 833b90f 331bf2d 833b90f 331bf2d 833b90f 331bf2d 833b90f 2625c97 f03488f b5ac14c d3beaf3 2625c97 73275a8 2625c97 92d5f88 |
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 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 |
# read the doc: https://huggingface.co/docs/hub/spaces-sdks-docker
# you will also find guides on how best to write your Dockerfile
FROM debian:bullseye-slim
# Install prerequisites
#RUN apt-get update -y && \
# apt-get install -y apt-transport-https ca-certificates gnupg curl
# Add the Cloud SDK distribution URI as a package source
#RUN echo "deb [signed-by=/usr/share/keyrings/cloud.google.asc] https://packages.cloud.google.com/apt cloud-sdk main" | tee -a /etc/apt/sources.list.d/google-cloud-sdk.list
# Import the Google Cloud public key
#RUN curl https://packages.cloud.google.com/apt/doc/apt-key.gpg | tee /usr/share/keyrings/cloud.google.asc
# Update the package list and install the Google Cloud CLI
#RUN apt-get update -y && apt-get install -y google-cloud-sdk
# You can include additional commands to configure or use the gcloud CLI here
# For example, you can authenticate with your service account key file:
#COPY your-service-account-key.json /tmp/key.json
#ENV GOOGLE_APPLICATION_CREDENTIALS=/tmp/key.json
#RUN gcloud auth activate-service-account --key-file=${GOOGLE_APPLICATION_CREDENTIALS}
# ... further instructions ...
ENV NVIDIA_VISIBLE_DEVICES all
ENV NVIDIA_DRIVER_CAPABILITIES compute,utility
ENV NVIDIA_REQUIRE_CUDA "cuda>=8.0"
ENV LD_LIBRARY_PATH=/usr/local/cuda-11.8/targets/x86_64-linux/lib:/usr/local/cuda-11.8/targets/x86_64-linux/include:/usr/local/cuda/include:/usr/local/cuda-11.8:/usr/local/cuda/lib:/usr/local/cuda/lib64:$LD_LIBRARY_PATH
#RUN dpkg --add-architecture amd64
#RUN apt-get update && \
# apt-get install -y --no-install-recommends gnupg2 curl ca-certificates
#RUN apt-key adv --fetch-keys https://developer.download.nvidia.com/compute/cuda/repos/debian11/x86_64/7fa2af80.pub
# Import the NVIDIA GPG key
#RUN apt-get update && apt-get install -y gnupg2 curl
# Fetch the NVIDIA repository GPG key
#RUN curl -fsSL https://developer.download.nvidia.com/compute/cuda/repos/debian11/x86_64/7fa2af80.pub | gpg --dearmor -o /usr/share/keyrings/cuda-archive-keyring.gpg
# Add the NVIDIA repository to the APT sources list
#RUN apt-key adv --fetch-keys https://developer.download.nvidia.com/compute/cuda/repos/ubuntu1804/x86_64/3bf863cc.pub
#RUN apt-key adv --fetch-keys https://developer.download.nvidia.com/compute/machine-learning/repos/ubuntu1804/x86_64/7fa2af80.pub
#RUN echo "deb https://developer.download.nvidia.com/compute/cuda/repos/debian11/x86_64 /" > /etc/apt/sources.list.d/cuda.list
# Install FFmpeg
RUN apt-get update && \
apt-get install -y python3-pip ffmpeg
#libcublas-11-8 libcudnn8=8.6.0.163-1+cuda11.8
#libcudnn8=8.8.0.121-1+cuda11.8
# Set the working directory to /code
WORKDIR /app
# Copy the requirements file into the container at /code/
#COPY ./requirements.txt /app/requirements.txt
# Copy the FastAP application code into the container
COPY ./ /app
#COPY ./interface.html /app/interface.html
#COPY ./styles.css /app/styles.css
# Install the required Python packages from requirements.txt
RUN pip install --no-cache-dir --upgrade -r requirements.txt
RUN pip install --upgrade fastapi authlib starlette
# Create a non-root user (optional but recommended for security)
RUN useradd -m -u 1000 user
# Switch to the non-root user
USER user
# Define environment variables
ENV HOME=/home/user \
PATH=/home/user/.local/bin:$PATH
# Change the working directory to /home/user/app
WORKDIR $HOME/app
# Copy the rest of the application files into the container
COPY --chown=user . $HOME/app
# Expose port 80 for the FastAPI application
EXPOSE 7860
# Specify the command to run your application (modify as needed)
CMD ["uvicorn", "app:app", "--host", "0.0.0.0", "--port", "7860"]
|