Files
website/Dockerfile
Steffen Illium 0aa6dfc5cf
All checks were successful
Next.js App CI / docker (push) Successful in 4m7s
Dockerfile experiments
2025-09-25 13:59:09 +02:00

58 lines
1.7 KiB
Docker

# Stage 1: Base image with Node.js and pnpm enabled
# This stage is used as a foundation for all subsequent stages.
FROM node:20-alpine AS base
ENV PNPM_HOME="/pnpm"
ENV PATH="$PNPM_HOME:$PATH"
RUN corepack enable && corepack prepare pnpm@latest --activate
# Stage 2: Builder
# This stage installs dependencies and builds the Next.js application.
FROM base AS builder
WORKDIR /app
# Install system dependencies needed for your scripts/build
RUN apk add --no-cache imagemagick libwebp libwebp-tools ghostscript
# Copy only the necessary files for installing dependencies
COPY package.json pnpm-lock.yaml ./
# Install ALL dependencies (including devDependencies needed for `next build`)
# This leverages the Docker cache effectively.
RUN pnpm install --frozen-lockfile
# Copy the rest of your application source code
COPY . .
# --- Asset Generation & Build ---
RUN chmod +x ./scripts/*.sh && ./scripts/first_page_image.sh
# The build command creates the .next/standalone directory
RUN pnpm build
# Stage 3: Runner (Production)
FROM base AS runner
WORKDIR /app
# Set NODE_ENV to production
ENV NODE_ENV=production
# Create a non-root user for security
RUN addgroup --system --gid 1001 nodejs
RUN adduser --system --uid 1001 nextjs
# Copy the standalone output from the builder
COPY --from=builder /app/.next/standalone ./
# Copy the public and static assets
COPY --from=builder /app/public ./public
COPY --from=builder /app/.next/static ./.next/static
# Change ownership to the non-root user
RUN chown -R nextjs:nodejs /app
# Switch to the non-root user
USER nextjs
EXPOSE 3000
ENV PORT=3000
# --- FINAL CMD CHANGED ---
# Directly run the standalone server.
CMD ["node", "server.js"]