Postat acum 1 zi
dockerfile
# Dockerfile
FROM node:22-alpine AS deps
WORKDIR /app
COPY package*.json ./
RUN npm ci
FROM node:22-alpine AS builder
WORKDIR /app
COPY --from=deps /app/node_modules ./node_modules
COPY . .
RUN npm run build
FROM node:22-alpine AS runner
WORKDIR /app
ENV NODE_ENV=production
RUN addgroup -g 1001 nodejs && adduser -S nextjs -u 1001
COPY --from=builder /app/public ./public
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
USER nextjs
EXPOSE 3000
CMD ["node", "server.js"]Imaginea default Next.js iese la ~1GB. Cu puțin efort cobori la 180MB și build-ul devine mai rapid în CI.
Pas 1 — Activezi standalone output
În next.config.js: output: 'standalone'. Așa primești un bundle minimal cu doar ce rulează.
Pas 2 — Multi-stage Dockerfile
- Stage 1:
node:22-alpinepentru deps și build - Stage 2: copiezi doar
.next/standalone+public+.next/static - Rulezi cu user non-root
Pas 3 — .dockerignore
Fără node_modules, fără .next local, fără .git.
Rezultat
- 180MB vs 1.2GB default
- Build în CI în 2 min vs 5 min
- Attack surface mai mică (nu mai ai dev deps în prod)