-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDockerfile
More file actions
53 lines (44 loc) · 1.36 KB
/
Dockerfile
File metadata and controls
53 lines (44 loc) · 1.36 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
## ---------- Base ----------
FROM node:24-alpine AS base
WORKDIR /app
## ---------- Development ----------
FROM base AS dev
ENV NODE_ENV=development \
SKIP_HUSKY=1
COPY package.json package-lock.json* ./
# Setup GitHub authentication for npm
ARG GITHUB_TOKEN
RUN echo "//npm.pkg.github.com/:_authToken=${GITHUB_TOKEN}" >> ~/.npmrc
RUN npm ci --omit=optional
COPY . .
# Default dev/debug ports (actual port comes from env)
EXPOSE 3012 9229
CMD ["npm", "run", "start:dev"]
## ---------- Builder ----------
FROM base AS builder
ENV NODE_ENV=development
COPY package.json package-lock.json* ./
# Setup GitHub authentication for npm
ARG GITHUB_TOKEN
RUN echo "//npm.pkg.github.com/:_authToken=${GITHUB_TOKEN}" >> ~/.npmrc
RUN npm ci --omit=optional
COPY . .
RUN npm run build
## ---------- Production ----------
FROM node:24-alpine AS production
ENV NODE_ENV=production \
SKIP_HUSKY=1
WORKDIR /app
# Install only production deps (tsconfig-paths is needed at runtime by start:prod)
COPY package.json package-lock.json* ./
RUN npm ci --omit=optional --only=production \
&& npm i --no-save tsconfig-paths@^4.2.0
# Copy built app
COPY --from=builder /app/dist ./dist
# Drop privileges
RUN addgroup -S nodejs && adduser -S nestjs -G nodejs \
&& chown -R nestjs:nodejs /app
USER nestjs
# Default prod port (actual port comes from env)
EXPOSE 3012
CMD ["npm", "run", "start:prod"]