saas_app/Dockerfile

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"]