# Use nvidia/cuda as base image with Python | |
FROM nvidia/cuda:12.2.2-cudnn8-runtime-ubuntu22.04 | |
# Use args | |
ARG USE_CUDA | |
ARG USE_CUDA_VER | |
## Basis ## | |
ENV ENV=prod \ | |
PORT=8000 \ | |
USE_CUDA_DOCKER=${USE_CUDA} \ | |
USE_CUDA_DOCKER_VER=${USE_CUDA_VER} | |
# Install GCC and build tools | |
RUN apt-get update && \ | |
apt-get install -y gcc build-essential curl git pkg-config libicu-dev && \ | |
apt-get clean && \ | |
rm -rf /var/lib/apt/lists/* | |
RUN apt-get update -y && apt-get install -y python3-pip | |
# Set working directory | |
WORKDIR /app | |
# Copy the requirements.txt file and install dependencies | |
COPY ./requirements.txt . | |
# Install dependencies | |
RUN pip install uv && \ | |
if [ "$USE_CUDA" = "true" ]; then \ | |
pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/$USE_CUDA_DOCKER_VER --no-cache-dir; \ | |
else \ | |
pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cpu --no-cache-dir; \ | |
fi | |
# Copy faster-whisper-main folder and install | |
COPY ./faster-whisper-main ./faster-whisper-main | |
RUN pip install ./faster-whisper-main --no-cache-dir | |
RUN pip install --no-cache-dir -r requirements.txt | |
# Copy the remaining application code | |
COPY . . | |
# Expose the API port | |
EXPOSE 8000 | |
# Set the environment variables | |
ENV HOST="0.0.0.0" | |
ENV PORT="8000" | |
# Set entrypoint to run the FastAPI server | |
ENTRYPOINT ["bash", "start.sh"] | |