-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile
64 lines (48 loc) · 1.7 KB
/
Dockerfile
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
# Use the official Node.js 20 image as a parent image
FROM node:20-alpine AS base
# Set the working directory
WORKDIR /app
# Install dependencies
FROM base AS deps
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed
RUN apk add --no-cache libc6-compat
COPY package.json package-lock.json* ./
RUN npm ci
# Rebuild the source code only when needed
FROM base AS builder
COPY --from=deps /app/node_modules ./node_modules
COPY . .
# This will do the trick, use the corresponding env file for each environment.
COPY .env .env
# Generate Prisma client
RUN npx prisma generate
# Build the Next.js app
RUN npm run build
# Production image, copy all the files and run next
FROM base AS runner
ENV NODE_ENV=production
COPY --from=builder /app/package.json ./package.json
# Set the correct permission for prerender cache
RUN mkdir .next
RUN chown node:node .next
# Automatically leverage output traces to reduce image size
# https://nextjs.org/docs/advanced-features/output-file-tracing
COPY --from=builder --chown=node:node /app/.next/standalone ./
COPY --from=builder --chown=node:node /app/.next/static ./.next/static
# Copy Prisma schema and migrations
COPY --from=builder /app/prisma ./prisma
# Install production dependencies including Prisma
RUN npm install --production
RUN npm install prisma @prisma/client
# Generate Prisma client
RUN npx prisma generate
# Add prisma CLI to PATH
ENV PATH=/app/node_modules/.bin:$PATH
USER node
EXPOSE 3000
ENV PORT=3000
ENV DATABASE_URL=file:/app/data/dev.db
# set hostname to localhost
ENV HOSTNAME="0.0.0.0"
# Use the custom script from package.json
CMD ["npm", "run", "start:migrate:prod"]