You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

54 lines
1.2 KiB

# 多阶段构建 - Next.js 生产镜像
# 阶段1: 依赖安装和构建
FROM node:20-alpine AS builder
WORKDIR /app
# 复制 package 文件
COPY package.json yarn.lock* ./
# 安装依赖
RUN yarn install --frozen-lockfile
# 复制源代码
COPY . .
# 构建应用
RUN yarn build
# 阶段2: 生产运行环境
FROM node:20-alpine AS runner
WORKDIR /app
ENV NODE_ENV=production
# 创建非root用户
RUN addgroup --system --gid 1001 nodejs
RUN adduser --system --uid 1001 nextjs
# 安装 sharp(Next.js standalone 模式需要)
# 安装必要的系统依赖
RUN apk add --no-cache libc6-compat vips-dev
# 复制 package.json 以安装 sharp
COPY --from=builder /app/package.json ./package.json
# 安装 sharp(使用 npm,因为 alpine 镜像默认包含 npm)
RUN npm install sharp@^0.33.0 --production
# 复制必要文件
COPY --from=builder /app/public ./public
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
# 复制 data 目录(运行时需要的 JSON 数据文件)
COPY --from=builder --chown=nextjs:nodejs /app/data ./data
USER nextjs
EXPOSE 3000
ENV PORT=3000
ENV HOSTNAME="0.0.0.0"
CMD ["node", "server.js"]