Files
microservice/Dockerfile.prod

55 lines
1.4 KiB
Docker

# Multi-stage build para optimizar el tamaño de la imagen
FROM python:3.11-slim AS builder
# Instalar dependencias de compilación
RUN apt-get update && apt-get install -y \
gcc \
g++ \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /app
COPY requirements.txt .
RUN pip install --user --no-cache-dir --verbose -r requirements.txt
# Imagen final de producción
FROM python:3.11-slim
# Variables de entorno para producción
ENV PYTHONDONTWRITEBYTECODE=1
ENV PYTHONUNBUFFERED=1
ENV PYTHONPATH=/app
ENV PATH=/home/fastapi/.local/bin:$PATH
ENV C_FORCE_ROOT=1
ENV REDIS_HOST=redis
ENV REDIS_PORT=6379
ENV REDIS_DB=0
# Crear usuario no-root para seguridad
RUN groupadd -r fastapi && useradd -r -g fastapi fastapi
# Instalar dependencias del sistema para Celery y Redis (sin supervisor)
RUN apt-get update && apt-get install -y \
curl \
redis-tools \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /app
# Instalar requirements en la imagen final para que los binarios estén disponibles
COPY requirements.txt ./
RUN pip install --no-cache-dir --verbose -r requirements.txt
# Copiar el código de la aplicación
COPY . .
# Crear directorios necesarios y establecer permisos
RUN mkdir -p /app/logs /app/uploads /app/temp && \
chown -R fastapi:fastapi /app && \
chmod -R 755 /app
# El comando se define en docker-compose para cada servicio (api, worker, beat, flower)
EXPOSE 8001