eduardweb.
Docker & ContainersIntermediar#docker#optimization#nextjs

Multi-stage Docker build pentru Next.js — imagine finală sub 200MB

De Paul Ene, 20 apr. 2026 · 672 vizualizări · 2 like-uri

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-alpine pentru 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)

Răspunsuri 0

Se încarcă răspunsurile…

Loghează-te pentru a răspunde

Doar membrii comunității pot lăsa comentarii.