- Update torch from 2.0.1 to 2.1.0 - Update torchaudio from 2.0.2 to 2.1.0 (fixes 'NoneType' object has no attribute 'eval' error) - Update torchvision from 0.15.2 to 0.16.0 - Update pytorch-lightning from 2.0.6 to 2.1.0 - Add explicit speechbrain==1.0.0 dependency - Update transformers and tokenizers for compatibility - Update protobuf version constraint Fixes diarization error: speechbrain.pretrained was deprecated and redirected to speechbrain.inference in SpeechBrain 1.0, but required torchaudio >= 2.1.0
45 lines
1.3 KiB
Docker
45 lines
1.3 KiB
Docker
FROM python:3.11-slim
|
|
|
|
# Set working directory
|
|
WORKDIR /app
|
|
|
|
# Install system dependencies
|
|
RUN apt-get update && apt-get install -y \
|
|
ffmpeg \
|
|
git \
|
|
wget \
|
|
curl \
|
|
build-essential \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Copy requirements first for better Docker layer caching
|
|
COPY requirements.txt .
|
|
|
|
# Install Python dependencies with pinned versions
|
|
RUN pip install --no-cache-dir -r requirements.txt
|
|
|
|
# Optional: Install CUDA-specific PyTorch if GPU support needed
|
|
# Uncomment and modify for your CUDA version:
|
|
# RUN pip install --force-reinstall torch==2.1.0+cu118 torchvision==0.16.0+cu118 torchaudio==2.1.0+cu118 --index-url https://download.pytorch.org/whl/cu118
|
|
|
|
# Copy application code
|
|
COPY . .
|
|
|
|
# Create directories for mounted volumes
|
|
RUN mkdir -p /app/data/videos /app/data/outputs /app/data/cache
|
|
|
|
# Set environment variables
|
|
ENV STREAMLIT_SERVER_PORT=8501
|
|
ENV STREAMLIT_SERVER_ADDRESS=0.0.0.0
|
|
ENV STREAMLIT_SERVER_HEADLESS=true
|
|
ENV STREAMLIT_BROWSER_GATHER_USAGE_STATS=false
|
|
|
|
# Expose Streamlit port
|
|
EXPOSE 8501
|
|
|
|
# Health check
|
|
HEALTHCHECK --interval=30s --timeout=10s --start-period=60s --retries=3 \
|
|
CMD curl -f http://localhost:8501/_stcore/health || exit 1
|
|
|
|
# Start the application
|
|
CMD ["streamlit", "run", "app.py", "--server.port=8501", "--server.address=0.0.0.0"] |