Last active
September 17, 2024 20:22
-
-
Save bizob2828/0fa170a9194838cab5dc8fbb00109425 to your computer and use it in GitHub Desktop.
Next.js with-docker Dockerfile update to get Node.js Next.js plugin to work
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| FROM node:18-alpine AS base | |
| # Install dependencies only when needed | |
| 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 | |
| WORKDIR /app | |
| # Install dependencies based on the preferred package manager | |
| COPY package.json yarn.lock* package-lock.json* pnpm-lock.yaml* ./ | |
| RUN \ | |
| if [ -f yarn.lock ]; then yarn --frozen-lockfile; \ | |
| elif [ -f package-lock.json ]; then npm ci; \ | |
| elif [ -f pnpm-lock.yaml ]; then corepack enable pnpm && pnpm i --frozen-lockfile; \ | |
| else echo "Lockfile not found." && exit 1; \ | |
| fi | |
| # Rebuild the source code only when needed | |
| FROM base AS builder | |
| WORKDIR /app | |
| COPY --from=deps /app/node_modules ./node_modules | |
| COPY . . | |
| # Next.js collects completely anonymous telemetry data about general usage. | |
| # Learn more here: https://nextjs.org/telemetry | |
| # Uncomment the following line in case you want to disable telemetry during the build. | |
| # ENV NEXT_TELEMETRY_DISABLED=1 | |
| RUN \ | |
| if [ -f yarn.lock ]; then yarn run build; \ | |
| elif [ -f package-lock.json ]; then npm run build; \ | |
| elif [ -f pnpm-lock.yaml ]; then corepack enable pnpm && pnpm run build; \ | |
| else echo "Lockfile not found." && exit 1; \ | |
| fi | |
| # Production image, copy all the files and run next | |
| FROM base AS runner | |
| WORKDIR /app | |
| ENV NODE_ENV=production | |
| # Uncomment the following line in case you want to disable telemetry during runtime. | |
| # ENV NEXT_TELEMETRY_DISABLED=1 | |
| RUN addgroup --system --gid 1001 nodejs | |
| RUN adduser --system --uid 1001 nextjs | |
| COPY --from=builder /app/public ./public | |
| # Set the correct permission for prerender cache | |
| RUN mkdir .next | |
| RUN chown nextjs:nodejs .next | |
| # Automatically leverage output traces to reduce image size | |
| # https://nextjs.org/docs/advanced-features/output-file-tracing | |
| COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./ | |
| COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static | |
| # Install the next.js plugin after it copies the standalone server and static bits to workdir | |
| # I cannot figure out why If I just install `@newrelic/next` and add to project's package.json | |
| # why it does not copy them over but it does not for some reason so we will add it after all the copying | |
| # occurs | |
| RUN npm i newrelic | |
| USER nextjs | |
| EXPOSE 3000 | |
| ENV PORT 3000 | |
| # server.js is created by next build from the standalone output | |
| # https://nextjs.org/docs/pages/api-reference/next-config-js/output | |
| ENV HOSTNAME="0.0.0.0" | |
| CMD ["node", "-r", "newrelic", "server.js"] |
Author
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
To get this working once you edit this file in: https://github.com/vercel/next.js/tree/canary/examples/with-docker
Run