-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathDockerfile
82 lines (68 loc) · 2.44 KB
/
Dockerfile
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
# Use the updated base CUDA image
FROM nvidia/cuda:11.8.0-cudnn8-runtime-ubuntu20.04
SHELL ["/bin/bash", "-o", "pipefail", "-c"]
# Set Work Directory
WORKDIR /app
# ARGs and ENVs
ARG WHISPER_MODEL=small
ARG LANG=en
ARG TORCH_HOME=/cache/torch
ARG HF_HOME=/cache/huggingface
# Environment variables
ENV TORCH_HOME=${TORCH_HOME}
ENV HF_HOME=${HF_HOME}
ENV WHISPER_MODEL=${WHISPER_MODEL}
ENV LANG=${LANG}
# Set LD_LIBRARY_PATH for library location (if still necessary)
ENV LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/lib/aarch64-linux-gnu/
ENV SHELL=/bin/bash
ENV PYTHONUNBUFFERED=True
ENV DEBIAN_FRONTEND=noninteractive
# Update, upgrade, install packages and clean up
RUN apt-get update && \
apt-get upgrade -y && \
apt-get install -y --no-install-recommends \
# Basic Utilities
bash ca-certificates curl file git ffmpeg \
# Python 3.10 and venv
software-properties-common && \
add-apt-repository ppa:deadsnakes/ppa && \
apt-get update && \
apt-get install -y python3.10 python3.10-venv python3.10-distutils && \
apt-get autoremove -y && \
apt-get clean && \
rm -rf /var/lib/apt/lists/* && \
# Set locale
echo "en_US.UTF-8 UTF-8" > /etc/locale.gen
# Create and activate virtual environment
RUN python3.10 -m venv /app/venv
ENV PATH="/app/venv/bin:$PATH"
# Install Python dependencies, setuptools-rust, PyTorch, and download WhisperX
RUN pip install --no-cache-dir --upgrade pip==21.* && \
pip install \
setuptools-rust==1.8.0 \
huggingface_hub==0.18.0 \
runpod==1.3.0 \
torch==2.0.0 \
torchvision==0.15.0 \
torchaudio==2.0.0 \
-f https://download.pytorch.org/whl/cu118/torch_stable.html
# Clone and install WhisperX
COPY ./whisperx /code
RUN pip install --no-cache-dir /code
# Preload Models
RUN python -c 'from whisperx.vad import load_vad_model; load_vad_model("cpu");' && \
python -c 'import faster_whisper; model = faster_whisper.WhisperModel("'${WHISPER_MODEL}'")'
# Preload align model
COPY load_align_model.py .
RUN python load_align_model.py ${LANG}
# Copy and install application-specific requirements
COPY requirements.txt /app/requirements.txt
RUN pip install --no-cache-dir -r requirements.txt
# COPY the example.mp3 file to the container as a default testing audio file
COPY example.mp3 /app/example.mp3
COPY handler.py /app/handler.py
COPY test_input.json /app/test_input.json
# Set Stop signal and CMD
STOPSIGNAL SIGINT
CMD ["python", "-u", "handler.py"]