From 39a2870131b7d482e9363f9ebf3d05b303d4701c Mon Sep 17 00:00:00 2001 From: javayhu Date: Sat, 21 Jun 2025 01:02:27 +0800 Subject: [PATCH 1/3] chore: support docker deployment --- Dockerfile | 59 ++++++++++++++++++++++++++++++++++++++++++++++++++ next.config.ts | 3 +++ 2 files changed, 62 insertions(+) create mode 100644 Dockerfile diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..2e9c05e --- /dev/null +++ b/Dockerfile @@ -0,0 +1,59 @@ +# syntax=docker/dockerfile:1 +FROM node:20-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 +COPY package.json pnpm-lock.yaml* ./ +RUN npm install -g pnpm && pnpm i --frozen-lockfile + +# 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 npm install -g pnpm \ + && DOCKER_BUILD=true pnpm build + +# 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 + +USER nextjs + +EXPOSE 3000 + +ENV PORT 3000 +ENV HOSTNAME "0.0.0.0" + +# server.js is created by next build from the standalone output +# https://nextjs.org/docs/pages/api-reference/next-config-js/output +CMD ["node", "server.js"] \ No newline at end of file diff --git a/next.config.ts b/next.config.ts index 6d7fb49..ac6ceeb 100644 --- a/next.config.ts +++ b/next.config.ts @@ -6,6 +6,9 @@ import createNextIntlPlugin from 'next-intl/plugin'; * https://nextjs.org/docs/app/api-reference/config/next-config-js */ const nextConfig: NextConfig = { + // Docker standalone output + ...(process.env.DOCKER_BUILD === 'true' && { output: 'standalone' }), + /* config options here */ devIndicators: false, From 5e1f9167e0e337960fb75f5f0f4e3f22ccd37bfe Mon Sep 17 00:00:00 2001 From: javayhu Date: Sat, 21 Jun 2025 01:23:31 +0800 Subject: [PATCH 2/3] fix: fix build error Cannot find config file --- Dockerfile | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/Dockerfile b/Dockerfile index 2e9c05e..1d3214f 100644 --- a/Dockerfile +++ b/Dockerfile @@ -9,6 +9,9 @@ WORKDIR /app # Install dependencies COPY package.json pnpm-lock.yaml* ./ +# Copy config files needed for fumadocs-mdx postinstall +COPY source.config.ts ./ +COPY content ./content RUN npm install -g pnpm && pnpm i --frozen-lockfile # Rebuild the source code only when needed @@ -29,7 +32,7 @@ RUN npm install -g pnpm \ FROM base AS runner WORKDIR /app -ENV NODE_ENV production +ENV NODE_ENV=production # Uncomment the following line in case you want to disable telemetry during runtime. # ENV NEXT_TELEMETRY_DISABLED 1 @@ -51,8 +54,8 @@ USER nextjs EXPOSE 3000 -ENV PORT 3000 -ENV HOSTNAME "0.0.0.0" +ENV PORT=3000 +ENV HOSTNAME="0.0.0.0" # server.js is created by next build from the standalone output # https://nextjs.org/docs/pages/api-reference/next-config-js/output From 1cb0793a8345b01948d00e116ff8f560ef609e78 Mon Sep 17 00:00:00 2001 From: javayhu Date: Sat, 21 Jun 2025 09:27:22 +0800 Subject: [PATCH 3/3] chore: change baseURL in fetch session --- src/middleware.ts | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/middleware.ts b/src/middleware.ts index 6292732..68635e9 100644 --- a/src/middleware.ts +++ b/src/middleware.ts @@ -3,6 +3,7 @@ import createMiddleware from 'next-intl/middleware'; import { type NextRequest, NextResponse } from 'next/server'; import { LOCALES, routing } from './i18n/routing'; import type { Session } from './lib/auth-types'; +import { getBaseUrl } from './lib/urls/urls'; import { DEFAULT_LOGIN_REDIRECT, protectedRoutes, @@ -30,7 +31,7 @@ export default async function middleware(req: NextRequest) { const { data: session } = await betterFetch( '/api/auth/get-session', { - baseURL: req.nextUrl.origin, + baseURL: getBaseUrl(), headers: { cookie: req.headers.get('cookie') || '', // Forward the cookies from the request },