feat: configurer Docker pour le build et l'exécution de l'application Next.js

This commit is contained in:
Puechberty Arthur
2026-03-31 19:26:44 +02:00
parent 6e2147a489
commit b54744a6d8
3 changed files with 49 additions and 7 deletions
+34
View File
@@ -0,0 +1,34 @@
# === Étape 1 : Build ===
FROM node:20-alpine AS builder
WORKDIR /app
# Copier les fichiers de dépendances pour profiter du cache Docker
COPY package*.json ./
# Installer uniquement ce qu'il faut pour le build
RUN npm ci
# Copier tout le code
COPY . .
# Build Next.js pour la production
RUN npm run build
# === Étape 2 : Runner léger ===
FROM node:20-alpine AS runner
WORKDIR /app
# Copier uniquement ce qui est nécessaire pour la prod
COPY --from=builder /app/package*.json ./
COPY --from=builder /app/node_modules ./node_modules
COPY --from=builder /app/.next ./.next
COPY --from=builder /app/public ./public
# Mode production
ENV NODE_ENV=production
EXPOSE 3000
# Lancer le serveur Next.js
CMD ["npm", "start"]
+7 -6
View File
@@ -1,10 +1,11 @@
services:
web:
image: node:20-alpine
working_dir: /app
build: .
ports:
- "3000:3000"
volumes:
- ./:/app
ports:
- "3004:3000"
command: sh -c "npm install && npm run build && npm start"
restart: unless-stopped
- /app/node_modules
environment:
- NODE_ENV=development
command: npm run dev
+8 -1
View File
@@ -1,7 +1,14 @@
import type { NextConfig } from "next";
const nextConfig: NextConfig = {
/* config options here */
// Mode production strict pour React (détecte les erreurs tôt)
reactStrictMode: true,
// Build standalone pour Docker → image finale légère et indépendante
output: "standalone",
// Compression des pages côté serveur (gzip/brotli)
compress: true,
};
export default nextConfig;