Docker
您可以轻松地在 Docker 上部署 Mkdirs。
使用 Dockerfile 部署
Mkdirs 提供了一个预配置的 Dockerfile 文件,方便你快速通过 Docker 部署导航站。
# Dockerfile
# syntax=docker/dockerfile:1FROM node:20-alpine AS base
# Install dependencies only when neededFROM 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-compatWORKDIR /app
# Install dependenciesCOPY package.json pnpm-lock.yaml* ./RUN corepack enable pnpm && pnpm i --frozen-lockfile
# Rebuild the source code only when neededFROM base AS builderWORKDIR /appCOPY --from=deps /app/node_modules ./node_modulesCOPY . .
# 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 corepack enable pnpm \ && mv next.config.docker.mjs next.config.mjs \ && pnpm build
# Production image, copy all the files and run nextFROM base AS runnerWORKDIR /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 nodejsRUN adduser --system --uid 1001 nextjs
COPY --from=builder /app/public ./public
# Set the correct permission for prerender cacheRUN mkdir .nextRUN chown nextjs:nodejs .next
# Automatically leverage output traces to reduce image size# https://nextjs.org/docs/advanced-features/output-file-tracingCOPY --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 3000ENV 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/outputCMD ["node", "server.js"]