File size: 1,571 Bytes
ac9e33e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
b2430fa
ac9e33e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
FROM nvidia/cuda:12.1.0-cudnn8-devel-ubuntu20.04
LABEL maintainer="Hugging Face"

ARG DEBIAN_FRONTEND=noninteractive

RUN apt update
RUN apt install -y git libsndfile1-dev tesseract-ocr espeak-ng python3 python3-pip ffmpeg
RUN python3 -m pip install --no-cache-dir --upgrade pip
# RUN apt-get install -y git libsndfile1-dev tesseract-ocr espeak-ng ffmpeg

# Prevents Python from writing pyc files.
ENV PYTHONDONTWRITEBYTECODE=1
# Open MP threads. It may need to change in production env.
ENV OMP_NUM_THREADS=1

# Keeps Python from buffering stdout and stderr to avoid situations where
# the application crashes without emitting any logs due to buffering.
ENV PYTHONUNBUFFERED=1

# ENV HF_HUB_CACHE="/hub"

WORKDIR /app

# Create a non-privileged user that the app will run under.
# See https://docs.docker.com/go/dockerfile-user-best-practices/
RUN useradd -m -u 1000 user
# Download dependencies as a separate step to take advantage of Docker's caching.
# Leverage a cache mount to /root/.cache/pip to speed up subsequent builds.
# Leverage a bind mount to requirements.txt to avoid having to copy them into
# into this layer.
RUN --mount=type=cache,target=/root/.cache/pip \
  --mount=type=bind,source=requirements.txt,target=requirements.txt \
  python3 -m pip install -r requirements.txt

# Switch to the non-privileged user to run the application.
USER user

# Copy the source code into the container.
COPY . .

# Expose the port that the application listens on.
EXPOSE 8088

# Run the application.
CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "7860"]