saas_app/Dockerfile
2025-12-09 13:09:10 -03:00

59 lines
1.5 KiB
Docker

# ==============================
# STAGE 1: Build da aplicação
# ==============================
FROM node:20-alpine AS builder
WORKDIR /app
# Define ambiente e proxy (opcional)
ENV NODE_ENV=production
ARG HTTP_PROXY
ARG HTTPS_PROXY
ENV NPM_CONFIG_HTTP_PROXY=$HTTP_PROXY
ENV NPM_CONFIG_HTTPS_PROXY=$HTTPS_PROXY
ENV NPM_CONFIG_TIMEOUT=600000
# Copia dependências e instala apenas as necessárias
COPY package.json package-lock.json ./
RUN npm ci --omit=dev --legacy-peer-deps
# ✅ Instala TypeScript globalmente (visível em todo build)
RUN npm install -g typescript
# Copia o restante do código
COPY . .
# Compila aplicação Next.js
RUN npm run build -- --no-lint
# ==============================
# STAGE 2: Imagem final (produção)
# ==============================
FROM node:20-alpine AS runner
WORKDIR /app
# Instala utilitários úteis e timezone
RUN apk add --no-cache nano curl tzdata
# Define timezone padrão
ENV TZ=America/Sao_Paulo
# Cria usuário não-root
RUN addgroup -g 1001 nodejs && adduser -u 1001 -G nodejs -s /bin/sh -D nodejs
# Copia apenas o necessário para execução
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
USER nodejs
ENV NODE_ENV=production
ENV PORT=3000
ENV HOSTNAME=0.0.0.0
EXPOSE 3000
HEALTHCHECK --interval=10s --timeout=3s --retries=3 \
CMD curl -f http://localhost:3000/ || exit 1
CMD ["node", "server.js"]