From ce9d05cd5ce3b788fd2563dff9bcd4858f70ac39 Mon Sep 17 00:00:00 2001 From: julien vdb Date: Thu, 5 Mar 2026 18:58:28 +0100 Subject: [PATCH] Fix dockerfile --- Dockerfile | 58 +++++++++++++----------------------------------------- 1 file changed, 14 insertions(+), 44 deletions(-) diff --git a/Dockerfile b/Dockerfile index ef80187..2eb1662 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,29 +1,7 @@ -# Creating multi-stage build for production -FROM node:18-alpine AS build -RUN apk update && apk add --no-cache build-base gcc autoconf automake zlib-dev libpng-dev vips-dev git > /dev/null 2>&1 -ARG NODE_ENV=production -ENV NODE_ENV=${NODE_ENV} +# --- ÉTAPE 1 : BUILD (On passe en Node 22) --- +FROM node:22-alpine AS build-stage -WORKDIR /opt/ -COPY package.json package-lock.json ./ -RUN npm install -g node-gyp -RUN npm config set fetch-retry-maxtimeout 600000 -g && npm install --only=production -ENV PATH=/opt/node_modules/.bin:$PATH -WORKDIR /opt/app -COPY . . -RUN npm run build - -# Creating final production image -FROM node:18-alpine -RUN apk add --no-cache vips-dev -ARG NODE_ENV=production -ENV NODE_ENV=${NODE_ENV} -WORKDIR /opt/ -COPY --from=build /opt/node_modules ./node_modules -WORKDIR /opt/app# --- ÉTAPE 1 : BUILD --- -FROM node:18-alpine AS build - -# Installation des dépendances système pour les modules natifs (Sharp, SWC, etc.) +# Installation des outils pour les modules natifs RUN apk update && apk add --no-cache \ build-base \ gcc \ @@ -38,21 +16,19 @@ ARG NODE_ENV=production ENV NODE_ENV=${NODE_ENV} WORKDIR /opt/ -# On copie package.json ET yarn.lock (très important) COPY package.json yarn.lock ./ -# On installe TOUTES les dépendances (y compris devDependencies pour le build) -# --frozen-lockfile assure que l'on utilise exactement les versions du lock +# On installe avec Yarn (Node 22 validera les "engines") RUN yarn install --frozen-lockfile WORKDIR /opt/app COPY . . -# On build l'admin et le code TS +# Build de l'admin et du code TS RUN yarn build -# --- ÉTAPE 2 : RUNTIME --- -FROM node:18-alpine +# --- ÉTAPE 2 : RUNTIME (Image finale légère) --- +FROM node:22-alpine AS runtime-stage RUN apk add --no-cache vips-dev libpng libjpeg-turbo ARG NODE_ENV=production @@ -60,24 +36,18 @@ ENV NODE_ENV=${NODE_ENV} WORKDIR /opt/app -# On récupère le dossier node_modules installé au stage précédent -# Et le code buildé (dist, build, etc.) -COPY --from=build /opt/node_modules ./node_modules -COPY --from=build /opt/app ./ +# On récupère les node_modules et le build du stage précédent +COPY --from=build-stage /opt/node_modules ./node_modules +COPY --from=build-stage /opt/app ./ -# On expose le binaire de strapi dans le PATH +# Configuration du PATH ENV PATH=/opt/app/node_modules/.bin:$PATH +# Sécurité : on utilise l'utilisateur 'node' au lieu de root RUN chown -R node:node /opt/app USER node EXPOSE 1337 -# On utilise yarn start qui lancera strapi depuis le dossier dist -CMD ["yarn", "start"] -COPY --from=build /opt/app ./ -ENV PATH=/opt/node_modules/.bin:$PATH -RUN chown -R node:node /opt/app -USER node -EXPOSE 1337 -CMD ["npm", "run", "start"] +# Une seule commande CMD à la fin +CMD ["yarn", "start"] \ No newline at end of file