# 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