#Prisma + Docker

2 messages · Page 1 of 1 (latest)

wicked reef
#

I have a Dockerfile:

###################
# BUILD FOR LOCAL DEVELOPMENT
###################

FROM node:20.9.0-alpine As development

# Create app directory
WORKDIR /usr/src/app

# Copy application dependency manifests to the container image.
# A wildcard is used to ensure copying both package.json AND package-lock.json (when available).
# Copying this first prevents re-running npm install on every code change.
COPY --chown=node:node package*.json ./

# Install app dependencies using the `npm ci` command instead of `npm install`
RUN npm ci --legacy-peer-deps

# Bundle app source
COPY --chown=node:node . .

# Use the node user from the image (instead of the root user)
USER node
#
###################
# BUILD FOR PRODUCTION
###################

FROM node:20.9.0-alpine As build

WORKDIR /usr/src/app

COPY --chown=node:node package*.json ./

# In order to run `npm run build` we need access to the Nest CLI which is a dev dependency. In the previous development stage we ran `npm ci` which installed all dependencies, so we can copy over the node_modules directory from the development image
COPY --chown=node:node --from=development /usr/src/app/node_modules ./node_modules

COPY --chown=node:node . .

# Generate Prisma client during the Docker build
RUN npx prisma generate

# Run the build command which creates the production bundle
RUN npm run build

# Set NODE_ENV environment variable
ENV NODE_ENV production

# Running `npm ci` removes the existing node_modules directory and passing in --omit=dev ensures that only the production dependencies are installed. This ensures that the node_modules directory is as optimized as possible
RUN npm ci --omit=dev --legacy-peer-deps && npm cache clean --force

USER node