# syntax=docker/dockerfile:1.6 # ---------- Stage 1 : deps ---------- FROM node:20-alpine AS deps RUN apk add --no-cache libc6-compat WORKDIR /app COPY package.json package-lock.json* ./ RUN npm ci # ---------- Stage 2 : build ---------- FROM node:20-alpine AS builder WORKDIR /app COPY --from=deps /app/node_modules ./node_modules COPY . . RUN npx prisma generate RUN npm run build # ---------- Stage 3 : runner ---------- FROM node:20-alpine AS runner WORKDIR /app ENV NODE_ENV=production ENV PORT=3000 # Outils système utiles à la découverte réseau # - iputils : ping ICMP (privileged / cap_net_raw) # - iproute2 : ip neigh (ARP) # - nmap : fallback scan ports (optionnel, décommente si besoin) RUN apk add --no-cache iputils iproute2 RUN addgroup --system --gid 1001 nodejs RUN adduser --system --uid 1001 nextjs 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 COPY --from=builder --chown=nextjs:nodejs /app/prisma ./prisma COPY --from=builder --chown=nextjs:nodejs /app/node_modules/.prisma ./node_modules/.prisma COPY --from=builder --chown=nextjs:nodejs /app/node_modules/@prisma ./node_modules/@prisma USER nextjs EXPOSE 3000 CMD ["node", "server.js"]