deploy(Dockerfile): Ajusta o dockerfile para produção

This commit is contained in:
Keven 2025-12-08 11:46:39 -03:00
parent 369dfcdfc3
commit 5f8d2cf670

View file

@ -1,26 +1,25 @@
# ==============================
# STAGE 1: Build da aplicação
# ==============================
# 💡 AJUSTE: Mudar para Node 20-alpine (LTS) para compatibilidade e segurança
FROM node:20-alpine AS builder
# 💡 AJUSTE: Criar usuário não-root mais cedo para garantir que os arquivos sejam criados corretamente
# durante o build, embora o Next.js recomende USER nodejs no final. Vamos manter o root por enquanto no build
# e mudar no runner.
WORKDIR /app
# 1. Copia arquivos de configuração de dependências
# Argumentos para configuração de proxy, se necessário
ARG HTTP_PROXY
ARG HTTPS_PROXY
# Define o proxy para o NPM, se os argumentos forem fornecidos.
ENV NPM_CONFIG_HTTP_PROXY=$HTTP_PROXY
ENV NPM_CONFIG_HTTPS_PROXY=$HTTPS_PROXY
ENV NPM_CONFIG_TIMEOUT=600000
COPY package.json package-lock.json ./
# 2. Instala dependências (incluindo dev para o build)
# O NPM 10+ (do Node 20) geralmente não precisa mais de --legacy-peer-deps, mas o mantive para segurança
RUN npm ci --include=dev --legacy-peer-deps
# 3. Copia o restante do código
COPY . .
# 4. Garante que o arquivo de configuração exista
# 💡 AJUSTE: Melhoria na sintaxe do shell e criação do arquivo
RUN mkdir -p src/config && \
if [ ! -f src/config/app.json ]; then \
echo '{ "APP_NAME": "Orius SaaS", "API_URL": "https://api.oriustecnologia.com" }' > src/config/app.json; \
@ -28,40 +27,30 @@ RUN mkdir -p src/config && \
ENV NODE_ENV=production
# 5. Gera o build otimizado
# Assumindo que 'npm run build' é o build do Next.js
# Gera o build otimizado
RUN npm run build -- --no-lint
# ==============================
# STAGE 2: Imagem final (produção)
# ==============================
# 💡 AJUSTE: Usar a mesma versão base para consistência e segurança
FROM node:20-alpine AS runner
WORKDIR /app
# 💡 AJUSTE: Next.js usa o diretório 'server' (standalone) para o ponto de entrada.
# Next.js recomenda copiar os diretórios exatos para garantir a integridade da imagem standalone.
# 1. Copia o diretório standalone inteiro (que inclui o server.js)
COPY --from=builder --chown=nodejs:nodejs /app/.next/standalone ./
# 2. Copia os arquivos estáticos
COPY --from=builder --chown=nodejs:nodejs /app/.next/static ./.next/static
# 3. Copia o diretório public
COPY --from=builder --chown=nodejs:nodejs /app/public ./public
# 💡 AJUSTE: Copia o arquivo server.js que é o entrypoint do Next.js standalone
COPY --from=builder --chown=nodejs:nodejs /app/server.js ./server.js
# 💡 AJUSTE: Copia apenas o necessário, package.json não é estritamente necessário se não for rodar npm scripts
# COPY --from=builder /app/package.json ./package.json
# Copia o arquivo de configuração
# 4. Copia a pasta de configuração
COPY --from=builder --chown=nodejs:nodejs /app/src/config ./src/config
# 💡 LINHA REMOVIDA:
# COPY --from=builder --chown=nodejs:nodejs /app/server.js ./server.js
# Cria e configura o usuário não-root antes de usá-lo
# 💡 AJUSTE: A base 'alpine' já tem 'adduser' e 'addgroup'. A Next.js recomenda o UID 1001.
# O user 'nodejs' já existe na imagem oficial do Node.js, mas o alpine é diferente, então criamos.
# No entanto, vamos tentar usar o usuário padrão Next.js:
# Cria e configura o usuário não-root
RUN addgroup -g 1001 nodejs && adduser -u 1001 -G nodejs -s /bin/sh -D nodejs
# 💡 AJUSTE: Next.js recomenda fortemente rodar como user 'nodejs'
USER nodejs
ENV NODE_ENV=production
@ -70,6 +59,5 @@ ENV HOSTNAME=0.0.0.0
EXPOSE 3000
# 💡 AJUSTE: O comando de execução do Next.js Standalone é rodar o arquivo server.js na raiz
# Note: Se você estiver usando um Next.js muito antigo, pode ser necessário 'node ./.next/standalone/server.js'
# Executa o server.js, que agora está na raiz do WORKDIR
CMD ["node", "server.js"]