mirror of
https://github.com/DrewThomasson/ebook2audiobook.git
synced 2026-01-09 13:58:14 -05:00
130 lines
7.1 KiB
Docker
130 lines
7.1 KiB
Docker
ARG BASE=python:3.12
|
|
ARG BASE_IMAGE=base
|
|
FROM ${BASE} AS base
|
|
|
|
# Set environment PATH for local installations
|
|
ENV PATH="/root/.local/bin:$PATH"
|
|
# Set non-interactive mode to prevent tzdata prompt
|
|
ENV DEBIAN_FRONTEND=noninteractive
|
|
# Install system packages
|
|
#RUN apt-get update && \
|
|
# apt-get install -y gcc g++ make wget git calibre ffmpeg libmecab-dev mecab mecab-ipadic-utf8 libsndfile1-dev libc-dev curl espeak-ng sox && \
|
|
# curl -fsSL https://deb.nodesource.com/setup_18.x | bash - && \
|
|
# apt-get install -y nodejs && \
|
|
# apt-get clean && \
|
|
# rm -rf /var/lib/apt/lists/*
|
|
# Install Rust compiler
|
|
#RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y
|
|
#path needed for rust installation?
|
|
ENV PATH="/root/.cargo/bin:${PATH}"
|
|
# Copy the application
|
|
WORKDIR /app
|
|
COPY . /app
|
|
# Install UniDic (non-torch dependent)
|
|
#RUN pip install --no-cache-dir unidic-lite unidic && \
|
|
# python3 -m unidic download && \
|
|
# mkdir -p /root/.local/share/unidic
|
|
#ENV UNIDIC_DIR=/root/.local/share/unidic
|
|
|
|
# Second stage for PyTorch installation + swappable base image if you want to use a pulled image
|
|
FROM $BASE_IMAGE AS pytorch
|
|
# Add parameter for PyTorch version with a default empty value
|
|
ARG TORCH_VERSION=""
|
|
# Add parameter to control whether to skip the XTTS test
|
|
ARG SKIP_XTTS_TEST="false"
|
|
|
|
|
|
# Extract torch versions from requirements.txt or set to empty strings if not found
|
|
#RUN TORCH_VERSION_REQ=$(grep -E "^torch==" requirements.txt | cut -d'=' -f3 || echo "") && \
|
|
# TORCHAUDIO_VERSION_REQ=$(grep -E "^torchaudio==" requirements.txt | cut -d'=' -f3 || echo "") && \
|
|
# TORCHVISION_VERSION_REQ=$(grep -E "^torchvision==" requirements.txt | cut -d'=' -f3 || echo "") && \
|
|
# echo "Found in requirements: torch==$TORCH_VERSION_REQ torchaudio==$TORCHAUDIO_VERSION_REQ torchvision==$TORCHVISION_VERSION_REQ"
|
|
|
|
# Install PyTorch with CUDA support if specified
|
|
#RUN if [ ! -z "$TORCH_VERSION" ]; then \
|
|
# # Check if we need to use specific versions or get the latest
|
|
# if [ ! -z "$TORCH_VERSION_REQ" ] && [ ! -z "$TORCHVISION_VERSION_REQ" ] && [ ! -z "$TORCHAUDIO_VERSION_REQ" ]; then \
|
|
# echo "Using specific versions from requirements.txt" && \
|
|
# TORCH_SPEC="torch==${TORCH_VERSION_REQ}" && \
|
|
# TORCHVISION_SPEC="torchvision==${TORCHVISION_VERSION_REQ}" && \
|
|
# TORCHAUDIO_SPEC="torchaudio==${TORCHAUDIO_VERSION_REQ}"; \
|
|
# else \
|
|
# echo "Using latest versions for the selected variant" && \
|
|
# TORCH_SPEC="torch" && \
|
|
# TORCHVISION_SPEC="torchvision" && \
|
|
# TORCHAUDIO_SPEC="torchaudio"; \
|
|
# fi && \
|
|
# \
|
|
# # Check if TORCH_VERSION contains "cuda" and extract version number
|
|
# if echo "$TORCH_VERSION" | grep -q "cuda"; then \
|
|
# CUDA_VERSION=$(echo "$TORCH_VERSION" | sed 's/cuda//g') && \
|
|
# echo "Detected CUDA version: $CUDA_VERSION" && \
|
|
# echo "Attempting to install PyTorch nightly for CUDA $CUDA_VERSION..." && \
|
|
# #if ! pip install --no-cache-dir --pre $TORCH_SPEC $TORCHVISION_SPEC $TORCHAUDIO_SPEC --index-url https://download.pytorch.org/whl/nightly/cu${CUDA_VERSION}; then \
|
|
# if ! pip install --no-cache-dir --pre torch torchvision torchaudio --index-url https://download.pytorch.org/whl/nightly/cu${CUDA_VERSION}; then \
|
|
# echo "❌ Nightly build for CUDA $CUDA_VERSION not available or failed" && \
|
|
# echo "🔄 Trying stable release for CUDA $CUDA_VERSION..." && \
|
|
# #if pip install --no-cache-dir $TORCH_SPEC $TORCHVISION_SPEC $TORCHAUDIO_SPEC --extra-index-url https://download.pytorch.org/whl/cu${CUDA_VERSION}; then \
|
|
# if pip install --no-cache-dir torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu${CUDA_VERSION}; then \
|
|
# echo "✅ Successfully installed stable PyTorch for CUDA $CUDA_VERSION"; \
|
|
# else \
|
|
# echo "❌ Both nightly and stable builds failed for CUDA $CUDA_VERSION"; \
|
|
# echo "💡 This CUDA version may not be supported by PyTorch"; \
|
|
# exit 1; \
|
|
# fi; \
|
|
# else \
|
|
# echo "✅ Successfully installed nightly PyTorch for CUDA $CUDA_VERSION"; \
|
|
# fi; \
|
|
# else \
|
|
# # Handle non-CUDA cases (existing functionality)
|
|
# case "$TORCH_VERSION" in \
|
|
# "rocm") \
|
|
# # Using the correct syntax for ROCm PyTorch installation
|
|
# pip install --no-cache-dir $TORCH_SPEC $TORCHVISION_SPEC $TORCHAUDIO_SPEC --extra-index-url https://download.pytorch.org/whl/rocm6.2 \
|
|
# ;; \
|
|
# "xpu") \
|
|
# # Install PyTorch with Intel XPU support through IPEX
|
|
# pip install --no-cache-dir $TORCH_SPEC $TORCHVISION_SPEC $TORCHAUDIO_SPEC && \
|
|
# pip install --no-cache-dir intel-extension-for-pytorch --extra-index-url https://pytorch-extension.intel.com/release-whl/stable/xpu/us/ \
|
|
# ;; \
|
|
# "cpu") \
|
|
# pip install --no-cache-dir $TORCH_SPEC $TORCHVISION_SPEC $TORCHAUDIO_SPEC --extra-index-url https://download.pytorch.org/whl/cpu \
|
|
# ;; \
|
|
# *) \
|
|
# pip install --no-cache-dir $TORCH_VERSION \
|
|
# ;; \
|
|
# esac; \
|
|
# fi && \
|
|
# # Install remaining requirements, skipping torch packages that might be there
|
|
# grep -v -E "^torch==|^torchvision==|^torchaudio==|^torchvision$" requirements.txt > requirements_no_torch.txt && \
|
|
# pip install --no-cache-dir --upgrade -r requirements_no_torch.txt && \
|
|
# rm requirements_no_torch.txt; \
|
|
# else \
|
|
# # Install all requirements as specified
|
|
# pip install --no-cache-dir --upgrade -r requirements.txt; \
|
|
# fi
|
|
|
|
# Do a test run to pre-download and bake base models into the image, but only if SKIP_XTTS_TEST is not true
|
|
#RUN if [ "$SKIP_XTTS_TEST" != "true" ]; then \
|
|
# echo "Running XTTS test to pre-download models..." && \
|
|
# echo "This is a test sentence." > test.txt && \
|
|
# if [ "$TORCH_VERSION" = "xpu" ]; then \
|
|
# TORCH_DEVICE_BACKEND_AUTOLOAD=0 python app.py --headless --ebook test.txt --script_mode full_docker; \
|
|
# else \
|
|
# python app.py --headless --ebook test.txt --script_mode full_docker; \
|
|
# fi && \
|
|
# rm test.txt; \
|
|
# else \
|
|
# echo "Skipping XTTS test run as requested."; \
|
|
# fi
|
|
RUN bash ./ebook2audiobook.sh --headless --script_mode full_docker --ebook tools/workflow-testing/test1.txt
|
|
# Expose the required port
|
|
EXPOSE 7860
|
|
# Start the Gradio app with the required flag
|
|
#ENTRYPOINT ["python", "app.py", "--script_mode", "full_docker"]
|
|
ENTRYPOINT ["bash" "./ebook2audiobook.sh" "--script_mode" "full_docker"]
|
|
|
|
#docker build --pull --build-arg BASE_IMAGE=athomasson2/ebook2audiobook:latest -t your-image-name .
|
|
#The --pull flag forces Docker to always try to pull the latest version of the image, even if it already exists locally.
|
|
#Without --pull, Docker will only use the local version if it exists, which might not be the latest.
|