Browse Source

add for deployment

Benjamin Kornblum 8 months ago
parent
commit
6c9d449bda
1 changed files with 19 additions and 8 deletions
  1. 19 8
      Dockerfile

+ 19 - 8
Dockerfile

@@ -1,19 +1,30 @@
-FROM node:22-alpine
-# Installing libvips-dev for sharp Compatibility
-RUN apk update && apk add --no-cache build-base gcc autoconf automake zlib-dev libpng-dev nasm bash vips-dev git
-ARG NODE_ENV=development
+# Creating multi-stage build for production
+FROM node:22-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}
 
 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
+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:22-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
+COPY --from=build /opt/app ./
+ENV PATH=/opt/node_modules/.bin:$PATH
+
 RUN chown -R node:node /opt/app
 USER node
-RUN ["npm", "run", "build"]
 EXPOSE 1337
-CMD ["npm", "run", "develop"]
+CMD ["npm", "run", "start"]