# 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/* # Crear directorio para las dependencias WORKDIR /app # Instalar dependencias globalmente COPY requirements.txt . RUN pip install --no-cache-dir --verbose -r requirements.txt # Imagen final FROM python:3.11-slim # 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 # Establecer variables de entorno para FastAPI y Celery ENV PYTHONDONTWRITEBYTECODE=1 ENV PYTHONUNBUFFERED=1 ENV PYTHONPATH=/app ENV PATH=/usr/local/bin:/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/* # Establecer directorio de trabajo WORKDIR / # 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) # Exponer puertos EXPOSE 8001 # Healthcheck para verificar que el servicio está funcionando HEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 \ CMD curl -f http://localhost:8001/api/v1/health || exit 1 # El comando se define en docker-compose para cada servicio (api, worker, beat, flower)