Files
todolist-fullstack/backend-api/Dockerfile

75 lines
2.3 KiB
Docker

# ============================================================================
# 🐳 Task Manager Backend - Dockerfile
# ============================================================================
# Build Multi-stage:
# 1. Builder: Compila TypeScript → JavaScript
# 2. Runner: Executa aplicação em produção
# ============================================================================
# ============================================================================
# STAGE 1: BUILDER (Compilação)
# ============================================================================
FROM node:20-alpine AS builder
WORKDIR /app
# Copiar package.json e package-lock.json
COPY package*.json ./
# Instalar dependências (incluindo dev)
RUN npm ci
# Copiar código-fonte
COPY . .
# Compilar TypeScript
RUN npm run build
# ============================================================================
# STAGE 2: RUNNER (Produção)
# ============================================================================
FROM node:20-alpine
WORKDIR /app
# 📝 Metadados da imagem
LABEL maintainer="Erik Silva <erik@stackbyte.com>"
LABEL version="1.0"
LABEL description="Task Manager API - Backend NestJS com Supabase"
# Definir NODE_ENV para produção
ENV NODE_ENV=production
# Copiar package.json (para saber quais dependências instalar)
COPY package*.json ./
# Instalar apenas dependências de produção
RUN npm ci --only=production && \
npm cache clean --force
# Copiar código compilado do builder
COPY --from=builder /app/dist ./dist
# Criar usuário não-root para segurança
RUN addgroup -g 1001 -S nodejs && \
adduser -S nodejs -u 1001
# Mudar propriedade dos arquivos
RUN chown -R nodejs:nodejs /app
# Mudar para usuário não-root
USER nodejs
# ============================================================================
# HEALTH CHECK
# ============================================================================
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
CMD node -e "require('http').get('http://localhost:3000/api', (r) => {if (r.statusCode !== 200) throw new Error(r.statusCode)})" || exit 1
# ============================================================================
# PORTA E COMANDO
# ============================================================================
EXPOSE 3000
CMD ["node", "dist/main.js"]