# Dockerfile optimisé pour la production Neah # Utilisé uniquement si vous déployez l'application complète avec Docker # Pour Vercel, ce fichier n'est pas nécessaire (Vercel build automatiquement) FROM node:22-alpine AS base # Installer les dépendances nécessaires pour Prisma RUN apk add --no-cache libc6-compat openssl WORKDIR /app # ============================================ # Étape 1: Dépendances # ============================================ FROM base AS deps COPY package.json package-lock.json* ./ RUN npm ci # ============================================ # Étape 2: Builder # ============================================ FROM base AS builder COPY --from=deps /app/node_modules ./node_modules COPY . . # Générer le client Prisma RUN npx prisma generate # Build Next.js (sans migrations - elles seront appliquées séparément) ENV NEXT_TELEMETRY_DISABLED=1 RUN npm run build # ============================================ # Étape 3: Runner (image finale) # ============================================ FROM base AS runner WORKDIR /app ENV NODE_ENV=production ENV NEXT_TELEMETRY_DISABLED=1 # Créer un utilisateur non-root pour la sécurité RUN addgroup --system --gid 1001 nodejs RUN adduser --system --uid 1001 nextjs # Copier les fichiers nécessaires depuis le builder COPY --from=builder /app/public ./public # Copier le build standalone de Next.js COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./ COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static # Copier Prisma (nécessaire pour le runtime) 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 # Copier le schéma Prisma (nécessaire pour certaines opérations) COPY --from=builder --chown=nextjs:nodejs /app/prisma ./prisma # Copier package.json pour les scripts Prisma COPY --from=builder --chown=nextjs:nodejs /app/package.json ./package.json USER nextjs EXPOSE 3000 ENV PORT=3000 ENV HOSTNAME="0.0.0.0" # Health check HEALTHCHECK --interval=30s --timeout=3s --start-period=40s --retries=3 \ CMD node -e "require('http').get('http://localhost:3000/api/health', (r) => {process.exit(r.statusCode === 200 ? 0 : 1)})" || exit 1 # Note: Les migrations Prisma doivent être appliquées séparément avant le démarrage # Utilisez: docker exec npx prisma migrate deploy CMD ["node", "server.js"]