-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDockerfile
More file actions
68 lines (49 loc) · 2.21 KB
/
Dockerfile
File metadata and controls
68 lines (49 loc) · 2.21 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
###################
# BUILD FOR LOCAL DEVELOPMENT
###################
FROM nikolaik/python-nodejs:python3.7-nodejs16-alpine As development
# Required for Prisma Client to work in container
# RUN apt-get update && apt-get install -y openssl
# 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 ./
COPY prisma ./prisma/
# Install app dependencies using the `npm ci` command instead of `npm install`
RUN npm i -g dotenv-cli
RUN npm ci
# Bundle app source
COPY --chown=node:node . .
# Generate Prisma database client code
RUN npm run prisma:generate
###################
# BUILD FOR PRODUCTION
###################
FROM nikolaik/python-nodejs:python3.7-nodejs16-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.
# The Nest CLI 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 into this build image.
COPY --chown=node:node --from=development /usr/src/app/node_modules ./node_modules
COPY --chown=node:node . .
# Run the build command which creates the production bundle
RUN npm run nx build backend
# Set NODE_ENV environment variable
ENV NODE_ENV production
# Running `npm ci` removes the existing node_modules directory.
# Passing in --only=production ensures that only the production dependencies are installed.
# This ensures that the node_modules directory is as optimized as possible.
RUN npm ci --only=production && npm cache clean --force
###################
# PRODUCTION
###################
FROM nikolaik/python-nodejs:python3.7-nodejs16-alpine As production
# Copy the bundled code from the build stage to the production image
COPY --chown=node:node --from=build /usr/src/app/node_modules ./node_modules
COPY --chown=node:node --from=build /usr/src/app/dist ./dist
# Start the server using the production build
CMD [ "node", "dist/apps/backend/main.js" ]