fix: move next build to image build time, drop yarn, add runner stage
- Build Next.js app during docker build (not on container start) — fixes yarn cache permission errors and makes container startup instant - Remove yarn.lock during build so nothing can accidentally invoke yarn - Add lean runner stage: copies only .next, node_modules, public — reduces final image size - npm start is now the only thing that runs at container start Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
45
Dockerfile
45
Dockerfile
@@ -1,30 +1,55 @@
|
|||||||
# https://nextjs.org/docs/deployment#docker-image
|
# ── Stage 1: install dependencies ──────────────────────────────────────────
|
||||||
|
|
||||||
FROM node:lts-alpine AS deps
|
FROM node:lts-alpine AS deps
|
||||||
RUN apk add --no-cache libc6-compat
|
RUN apk add --no-cache libc6-compat
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
COPY package.json package-lock.json* ./
|
COPY package.json package-lock.json* ./
|
||||||
RUN npm install --legacy-peer-deps
|
RUN npm install --legacy-peer-deps
|
||||||
|
|
||||||
|
# ── Stage 2: build the Next.js app ──────────────────────────────────────────
|
||||||
FROM node:lts-alpine AS builder
|
FROM node:lts-alpine AS builder
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
|
# Create non-root user
|
||||||
|
RUN addgroup -g 1001 -S nodejs && \
|
||||||
|
adduser -S nextjs -u 1001
|
||||||
|
|
||||||
|
# Copy source and deps
|
||||||
|
COPY --chown=nextjs:nodejs . .
|
||||||
|
COPY --from=deps --chown=nextjs:nodejs /app/node_modules ./node_modules
|
||||||
|
|
||||||
|
# Remove yarn.lock so nothing accidentally invokes yarn
|
||||||
|
RUN rm -f yarn.lock
|
||||||
|
|
||||||
|
# Ensure data dir is writable at runtime
|
||||||
|
RUN mkdir -p /app/data && chown -R nextjs:nodejs /app/data && chmod 755 /app/data
|
||||||
|
|
||||||
|
# Build the app at image build time (not at container start)
|
||||||
|
USER nextjs
|
||||||
|
ENV NODE_ENV=production
|
||||||
|
ENV NEXT_TELEMETRY_DISABLED=1
|
||||||
|
RUN npm run build
|
||||||
|
|
||||||
|
# ── Stage 3: production runner ───────────────────────────────────────────────
|
||||||
|
FROM node:lts-alpine AS runner
|
||||||
RUN apk add --no-cache curl
|
RUN apk add --no-cache curl
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
RUN addgroup -g 1001 -S nodejs && \
|
RUN addgroup -g 1001 -S nodejs && \
|
||||||
adduser -S nextjs -u 1001
|
adduser -S nextjs -u 1001
|
||||||
|
|
||||||
COPY --chown=nextjs:nodejs . .
|
# Copy only what's needed to run
|
||||||
COPY --from=deps --chown=nextjs:nodejs /app/node_modules ./node_modules
|
COPY --from=builder --chown=nextjs:nodejs /app/public ./public
|
||||||
|
COPY --from=builder --chown=nextjs:nodejs /app/.next ./.next
|
||||||
|
COPY --from=builder --chown=nextjs:nodejs /app/node_modules ./node_modules
|
||||||
|
COPY --from=builder --chown=nextjs:nodejs /app/package.json ./package.json
|
||||||
|
COPY --from=builder --chown=nextjs:nodejs /app/next.config.js ./next.config.js
|
||||||
|
|
||||||
# Ensure the data directory exists and is writable by the nextjs user
|
|
||||||
RUN mkdir -p /app/data && chown -R nextjs:nodejs /app/data && chmod 755 /app/data
|
RUN mkdir -p /app/data && chown -R nextjs:nodejs /app/data && chmod 755 /app/data
|
||||||
|
|
||||||
USER nextjs
|
USER nextjs
|
||||||
|
|
||||||
EXPOSE 3000
|
EXPOSE 3000
|
||||||
|
ENV NODE_ENV=production
|
||||||
ENV NODE_ENV production
|
ENV NEXT_TELEMETRY_DISABLED=1
|
||||||
ENV NEXT_TELEMETRY_DISABLED 1
|
|
||||||
|
|
||||||
HEALTHCHECK --interval=1m --timeout=3s CMD curl -f http://localhost:3000/ || exit 1
|
HEALTHCHECK --interval=1m --timeout=3s CMD curl -f http://localhost:3000/ || exit 1
|
||||||
|
|
||||||
@@ -32,4 +57,4 @@ CMD NEXT_PUBLIC_SITE_DOMAIN=$site_domain \
|
|||||||
NEXT_PUBLIC_FORCE_DEFAULT_THEME=$force_default_theme \
|
NEXT_PUBLIC_FORCE_DEFAULT_THEME=$force_default_theme \
|
||||||
NEXT_PUBLIC_DEFAULT_SOURCE_LANG=$default_source_lang \
|
NEXT_PUBLIC_DEFAULT_SOURCE_LANG=$default_source_lang \
|
||||||
NEXT_PUBLIC_DEFAULT_TARGET_LANG=$default_target_lang \
|
NEXT_PUBLIC_DEFAULT_TARGET_LANG=$default_target_lang \
|
||||||
npm run build && npm start
|
npm start
|
||||||
|
|||||||
Reference in New Issue
Block a user