75 lines
No EOL
3 KiB
Docker
75 lines
No EOL
3 KiB
Docker
# ==============================
|
|
# 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
|
|
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; \
|
|
fi
|
|
|
|
ENV NODE_ENV=production
|
|
|
|
# 5. Gera o build otimizado
|
|
# Assumindo que 'npm run build' é o build do Next.js
|
|
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.
|
|
COPY --from=builder --chown=nodejs:nodejs /app/.next/standalone ./
|
|
COPY --from=builder --chown=nodejs:nodejs /app/.next/static ./.next/static
|
|
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
|
|
COPY --from=builder --chown=nodejs:nodejs /app/src/config ./src/config
|
|
|
|
|
|
# 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:
|
|
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
|
|
ENV PORT=3000
|
|
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'
|
|
CMD ["node", "server.js"] |