Closed3
turborepoで作ったNext.jsアプリケーションをpnpmを用いてstandalone Dockerビルドする

apps/web/next.config.js
/** @type {import('next').NextConfig} */
module.exports = {
transpilePackages: ["@repo/ui"],
output: "standalone",
};
Dockerfile
FROM node:18-alpine AS base
ENV PNPM_HOME="/pnpm"
ENV PATH="$PNPM_HOME:$PATH"
RUN corepack enable
FROM base AS builder
RUN apk add --no-cache libc6-compat
RUN apk update
WORKDIR /app
RUN pnpm add -g turbo
COPY . .
RUN turbo prune web --docker
FROM base AS installer
RUN apk add --no-cache libc6-compat
RUN apk update
WORKDIR /app
COPY .gitignore .gitignore
COPY /app/out/json/ .
COPY /app/out/pnpm-lock.yaml ./
RUN pnpm install
COPY /app/out/full/ .
RUN pnpm turbo run build --filter=web
FROM base AS runner
WORKDIR /app
RUN addgroup --system --gid 1001 nodejs
RUN adduser --system --uid 1001 nextjs
USER nextjs
COPY /app/apps/web/next.config.js .
COPY /app/apps/web/package.json .
COPY /app/apps/web/.next/standalone ./
COPY /app/apps/web/.next/static ./apps/web/.next/static
COPY /app/apps/web/public ./apps/web/public
ENV HOSTNAME=0.0.0.0
CMD node apps/web/server.js
このスクラップは2024/04/17にクローズされました