Multi-stage Dockerfile để minimize production image size:
dockerfile
# Stage 1: Build
FROM node:20-alpine AS builder
WORKDIR /app
COPY package*.json pnpm-lock.yaml ./
RUN npm install -g pnpm && pnpm install --frozen-lockfile
COPY . .
RUN pnpm build
# Stage 2: Production
FROM node:20-alpine AS production
WORKDIR /app
# Chỉ copy prod dependencies
COPY --from=builder /app/dist ./dist
COPY --from=builder /app/node_modules ./node_modules
COPY --from=builder /app/package.json .
# Non-root user
RUN addgroup -g 1001 -S nodejs && adduser -S nestjs -u 1001
USER nestjs
EXPOSE 3000
CMD ["node", "dist/main.js"]docker-compose cho development:
yaml
services:
api:
build: .
ports: ['3000:3000']
environment:
- DATABASE_URL=postgresql://user:pass@db:5432/mydb
depends_on: [db, redis]
db:
image: postgres:16-alpine
volumes: ['pgdata:/var/lib/postgresql/data']Best practices: dùng non-root user, .dockerignore exclude node_modules/dist, health check trong Dockerfile.