SolyQuiz/Dockerfile
corenthin-lebreton 3548eabf68 Dockerfile modif2
2026-02-26 22:17:14 +01:00

84 lines
3.2 KiB
Docker

# ─────────────────────────────────────────────────────────────
# Étape 1 — Installation des dépendances
# ─────────────────────────────────────────────────────────────
FROM node:20-alpine AS deps
RUN apk update && apk upgrade --no-cache && apk add --no-cache libc6-compat
WORKDIR /app
COPY package.json package-lock.json* ./
RUN npm ci
# ─────────────────────────────────────────────────────────────
# Étape 2 — Build de l'application
# ─────────────────────────────────────────────────────────────
FROM node:20-alpine AS builder
RUN apk update && apk upgrade --no-cache && apk add --no-cache libc6-compat
WORKDIR /app
COPY --from=deps /app/node_modules ./node_modules
COPY . .
# Variables publiques nécessaires à la compilation du bundle client.
# Passer via --build-arg ou docker-compose (voir docker-compose.yml).
# Les valeurs vides sont acceptées : les pages sont dynamiques (cookies),
# donc aucune pré-rendu statique ne les utilise au build.
ARG NEXT_PUBLIC_SUPABASE_URL=""
ARG NEXT_PUBLIC_SUPABASE_ANON_KEY=""
ENV NEXT_PUBLIC_SUPABASE_URL=$NEXT_PUBLIC_SUPABASE_URL \
NEXT_PUBLIC_SUPABASE_ANON_KEY=$NEXT_PUBLIC_SUPABASE_ANON_KEY \
NEXT_TELEMETRY_DISABLED=1 \
NODE_ENV=production \
# Allouer suffisamment de mémoire pour le build Next.js
NODE_OPTIONS="--max-old-space-size=4096"
RUN npm run build
# ─────────────────────────────────────────────────────────────
# Étape 3 — Image de production minimale et durcie
# ─────────────────────────────────────────────────────────────
FROM node:20-alpine AS runner
RUN apk update && apk upgrade --no-cache
WORKDIR /app
# Utilisateur non-root dédié
RUN addgroup --system --gid 1001 nodejs && \
adduser --system --uid 1001 nextjs
# Fichiers publics (favicon, images statiques…)
COPY --from=builder /app/public ./public
# Serveur Next.js standalone (bundle minimal, sans node_modules complets)
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
# Assets statiques compilés (_next/static)
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
USER nextjs
ENV NODE_ENV=production \
NEXT_TELEMETRY_DISABLED=1 \
PORT=3000 \
HOSTNAME="0.0.0.0"
# Secrets injectés au runtime uniquement (jamais baked dans l'image) :
# NEXT_PUBLIC_SUPABASE_URL
# NEXT_PUBLIC_SUPABASE_ANON_KEY
# SUPABASE_SERVICE_ROLE_KEY
EXPOSE 3000
HEALTHCHECK --interval=30s --timeout=10s --start-period=20s --retries=3 \
CMD wget -qO- http://localhost:3000/ | grep -q "html" || exit 1
CMD ["node", "server.js"]