# Multi-stage build para otimizar tamanho da imagem FROM python:3.11-slim as builder # Instalar dependências do sistema necessárias para compilação RUN apt-get update && apt-get install -y \ gcc \ g++ \ && rm -rf /var/lib/apt/lists/* # Criar diretório de trabalho WORKDIR /app # Copiar requirements e instalar dependências Python COPY requirements.txt . RUN pip install --no-cache-dir --user -r requirements.txt # Stage final - imagem de produção FROM python:3.11-slim # Instalar dependências de runtime RUN apt-get update && apt-get install -y \ curl \ && rm -rf /var/lib/apt/lists/* # Criar usuário não-root RUN groupadd -r appuser && useradd -r -g appuser appuser # Criar diretórios necessários RUN mkdir -p /app /tmp/reports && \ chown -R appuser:appuser /app /tmp/reports # Instalar dependências Python globalmente COPY requirements.txt . RUN pip install --no-cache-dir -r requirements.txt # Definir diretório de trabalho WORKDIR /app # Copiar código da aplicação COPY app/ ./app/ # Alterar propriedade dos arquivos RUN chown -R appuser:appuser /app # Mudar para usuário não-root USER appuser # Expor porta EXPOSE 8080 # Health check HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \ CMD curl -f http://localhost:8080/health || exit 1 # Tornar scripts executáveis RUN chmod +x ./app/workers/celery_worker.py ./app/workers/celery_beat.py # Comando para executar a aplicação CMD ["python", "-m", "uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8080"]