misc: update Dockerfile for next 16
This commit is contained in:
114
Dockerfile
114
Dockerfile
@@ -1,66 +1,112 @@
|
|||||||
# syntax=docker.io/docker/dockerfile:1
|
# ============================================
|
||||||
|
# Stage 1: Dependencies Installation Stage
|
||||||
|
# ============================================
|
||||||
|
|
||||||
FROM node:18-alpine AS base
|
# IMPORTANT: Node.js Version Maintenance
|
||||||
|
# This Dockerfile uses Node.js 24.13.0-slim, which was the latest LTS version at the time of writing.
|
||||||
|
# To ensure security and compatibility, regularly update the NODE_VERSION ARG to the latest LTS version.
|
||||||
|
ARG NODE_VERSION=24.13.0-slim
|
||||||
|
|
||||||
# Install dependencies only when needed
|
FROM node:${NODE_VERSION} AS dependencies
|
||||||
FROM base AS deps
|
|
||||||
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed.
|
# Set working directory
|
||||||
RUN apk add --no-cache libc6-compat
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
# Install dependencies based on the preferred package manager
|
# Copy package-related files first to leverage Docker's caching mechanism
|
||||||
COPY package.json yarn.lock* package-lock.json* pnpm-lock.yaml* .npmrc* ./
|
COPY package.json yarn.lock* package-lock.json* pnpm-lock.yaml* .npmrc* ./
|
||||||
RUN \
|
|
||||||
if [ -f yarn.lock ]; then yarn --frozen-lockfile; \
|
# Install project dependencies with frozen lockfile for reproducible builds
|
||||||
elif [ -f package-lock.json ]; then npm ci; \
|
RUN --mount=type=cache,target=/root/.npm \
|
||||||
elif [ -f pnpm-lock.yaml ]; then corepack enable pnpm && pnpm i --frozen-lockfile; \
|
--mount=type=cache,target=/usr/local/share/.cache/yarn \
|
||||||
else echo "Lockfile not found." && exit 1; \
|
--mount=type=cache,target=/root/.local/share/pnpm/store \
|
||||||
|
if [ -f package-lock.json ]; then \
|
||||||
|
npm ci --no-audit --no-fund; \
|
||||||
|
elif [ -f yarn.lock ]; then \
|
||||||
|
corepack enable yarn && yarn install --frozen-lockfile --production=false; \
|
||||||
|
elif [ -f pnpm-lock.yaml ]; then \
|
||||||
|
corepack enable pnpm && pnpm install --frozen-lockfile; \
|
||||||
|
else \
|
||||||
|
echo "No lockfile found." && exit 1; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# ============================================
|
||||||
|
# Stage 2: Build Next.js application in standalone mode
|
||||||
|
# ============================================
|
||||||
|
|
||||||
# Rebuild the source code only when needed
|
FROM node:${NODE_VERSION} AS builder
|
||||||
FROM base AS builder
|
|
||||||
|
# Set working directory
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
COPY --from=deps /app/node_modules ./node_modules
|
|
||||||
|
# Copy project dependencies from dependencies stage
|
||||||
|
COPY --from=dependencies /app/node_modules ./node_modules
|
||||||
|
|
||||||
|
# Copy application source code
|
||||||
COPY . .
|
COPY . .
|
||||||
|
|
||||||
|
ENV NODE_ENV=production
|
||||||
|
|
||||||
# Next.js collects completely anonymous telemetry data about general usage.
|
# Next.js collects completely anonymous telemetry data about general usage.
|
||||||
# Learn more here: https://nextjs.org/telemetry
|
# Learn more here: https://nextjs.org/telemetry
|
||||||
# Uncomment the following line in case you want to disable telemetry during the build.
|
# Uncomment the following line in case you want to disable telemetry during the build.
|
||||||
# ENV NEXT_TELEMETRY_DISABLED=1
|
# ENV NEXT_TELEMETRY_DISABLED=1
|
||||||
|
|
||||||
RUN \
|
# Build Next.js application
|
||||||
if [ -f yarn.lock ]; then yarn run build; \
|
# If you want to speed up Docker rebuilds, you can cache the build artifacts
|
||||||
elif [ -f package-lock.json ]; then npm run build; \
|
# by adding: --mount=type=cache,target=/app/.next/cache
|
||||||
elif [ -f pnpm-lock.yaml ]; then corepack enable pnpm && pnpm run build; \
|
# This caches the .next/cache directory across builds, but it also prevents
|
||||||
else echo "Lockfile not found." && exit 1; \
|
# .next/cache/fetch-cache from being included in the final image, meaning
|
||||||
|
# cached fetch responses from the build won't be available at runtime.
|
||||||
|
RUN if [ -f package-lock.json ]; then \
|
||||||
|
npm run build; \
|
||||||
|
elif [ -f yarn.lock ]; then \
|
||||||
|
corepack enable yarn && yarn build; \
|
||||||
|
elif [ -f pnpm-lock.yaml ]; then \
|
||||||
|
corepack enable pnpm && pnpm build; \
|
||||||
|
else \
|
||||||
|
echo "No lockfile found." && exit 1; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Production image, copy all the files and run next
|
# ============================================
|
||||||
FROM base AS runner
|
# Stage 3: Run Next.js application
|
||||||
|
# ============================================
|
||||||
|
|
||||||
|
FROM node:${NODE_VERSION} AS runner
|
||||||
|
|
||||||
|
# Set working directory
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
|
# Set production environment variables
|
||||||
ENV NODE_ENV=production
|
ENV NODE_ENV=production
|
||||||
# Uncomment the following line in case you want to disable telemetry during runtime.
|
ENV PORT=3000
|
||||||
|
ENV HOSTNAME="0.0.0.0"
|
||||||
|
|
||||||
|
# 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 run time.
|
||||||
# ENV NEXT_TELEMETRY_DISABLED=1
|
# ENV NEXT_TELEMETRY_DISABLED=1
|
||||||
|
|
||||||
RUN addgroup --system --gid 1001 nodejs
|
# Copy production assets
|
||||||
RUN adduser --system --uid 1001 nextjs
|
COPY --from=builder --chown=node:node /app/public ./public
|
||||||
|
|
||||||
COPY --from=builder /app/public ./public
|
# Set the correct permission for prerender cache
|
||||||
|
RUN mkdir .next
|
||||||
|
RUN chown node:node .next
|
||||||
|
|
||||||
# Automatically leverage output traces to reduce image size
|
# Automatically leverage output traces to reduce image size
|
||||||
# https://nextjs.org/docs/advanced-features/output-file-tracing
|
# https://nextjs.org/docs/advanced-features/output-file-tracing
|
||||||
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
|
COPY --from=builder --chown=node:node /app/.next/standalone ./
|
||||||
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
|
COPY --from=builder --chown=node:node /app/.next/static ./.next/static
|
||||||
|
|
||||||
USER nextjs
|
# If you want to persist the fetch cache generated during the build so that
|
||||||
|
# cached responses are available immediately on startup, uncomment this line:
|
||||||
|
# COPY --from=builder --chown=node:node /app/.next/cache ./.next/cache
|
||||||
|
|
||||||
|
# Switch to non-root user for security best practices
|
||||||
|
USER node
|
||||||
|
|
||||||
|
# Expose port 3000 to allow HTTP traffic
|
||||||
EXPOSE 3000
|
EXPOSE 3000
|
||||||
|
|
||||||
ENV PORT=3000
|
# Start Next.js standalone server
|
||||||
|
|
||||||
# server.js is created by next build from the standalone output
|
|
||||||
# https://nextjs.org/docs/pages/api-reference/config/next-config-js/output
|
|
||||||
ENV HOSTNAME="0.0.0.0"
|
|
||||||
CMD ["node", "server.js"]
|
CMD ["node", "server.js"]
|
||||||
@@ -1,7 +1,11 @@
|
|||||||
{
|
{
|
||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
"target": "ES2017",
|
"target": "ES2017",
|
||||||
"lib": ["dom", "dom.iterable", "esnext"],
|
"lib": [
|
||||||
|
"dom",
|
||||||
|
"dom.iterable",
|
||||||
|
"esnext"
|
||||||
|
],
|
||||||
"allowJs": true,
|
"allowJs": true,
|
||||||
"skipLibCheck": true,
|
"skipLibCheck": true,
|
||||||
"strict": true,
|
"strict": true,
|
||||||
@@ -11,7 +15,7 @@
|
|||||||
"moduleResolution": "bundler",
|
"moduleResolution": "bundler",
|
||||||
"resolveJsonModule": true,
|
"resolveJsonModule": true,
|
||||||
"isolatedModules": true,
|
"isolatedModules": true,
|
||||||
"jsx": "preserve",
|
"jsx": "react-jsx",
|
||||||
"incremental": true,
|
"incremental": true,
|
||||||
"plugins": [
|
"plugins": [
|
||||||
{
|
{
|
||||||
@@ -19,9 +23,19 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"paths": {
|
"paths": {
|
||||||
"@/*": ["./src/*"]
|
"@/*": [
|
||||||
|
"./src/*"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts"],
|
"include": [
|
||||||
"exclude": ["node_modules"]
|
"next-env.d.ts",
|
||||||
|
"**/*.ts",
|
||||||
|
"**/*.tsx",
|
||||||
|
".next/types/**/*.ts",
|
||||||
|
".next/dev/types/**/*.ts"
|
||||||
|
],
|
||||||
|
"exclude": [
|
||||||
|
"node_modules"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user