rss/Dockerfile
2025-10-17 04:10:09 +02:00

49 lines
1.4 KiB
Docker

# Imagen base Python
FROM python:3.11-slim
# Por defecto construimos para CUDA 12.1 (cu121)
# Si alguna vez quisieras CPU, pásale: --build-arg TORCH_CUDA=cpu
ARG TORCH_CUDA=cu121
WORKDIR /app
# Paquetes nativos necesarios
RUN apt-get update && apt-get install -y --no-install-recommends \
libpq-dev \
gcc \
git \
&& rm -rf /var/lib/apt/lists/*
# Requerimientos
COPY requirements.txt .
# Actualiza pip y herramientas base
RUN python -m pip install --no-cache-dir --upgrade pip setuptools wheel
# Instala PyTorch con el runtime CUDA 12.1 (o CPU si TORCH_CUDA=cpu)
RUN if [ "$TORCH_CUDA" = "cu121" ]; then \
pip install --no-cache-dir --index-url https://download.pytorch.org/whl/cu121 \
torch==2.4.1 torchvision==0.19.1 torchaudio==2.4.1; \
else \
pip install --no-cache-dir \
torch==2.4.1 torchvision==0.19.1 torchaudio==2.4.1; \
fi
# Instala el resto de dependencias de tu app
RUN pip install --no-cache-dir -r requirements.txt
# spaCy + modelo español (para el NER que quieres después)
RUN pip install --no-cache-dir "spacy>=3.7,<4.0" \
&& python -m spacy download es_core_news_md
# Copia el código
COPY . .
# (Opcional) descarga recursos NLTK si tu app los usa; si no, déjalo como no-op
RUN python download_models.py || true
# Puerto que usará gunicorn en el servicio web
EXPOSE 8000
# El CMD lo define docker-compose