Dockerfile.prod 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. # Stage 1: Dependencies
  2. FROM node:18-alpine AS deps
  3. WORKDIR /app
  4. # 安装 pnpm
  5. RUN npm install -g pnpm
  6. # 安装 bash 和其他必要的工具
  7. RUN apk add --no-cache libc6-compat bash
  8. # 复制 package.json 和 pnpm-lock.yaml(如果有的话)
  9. COPY package.json pnpm-lock.yaml* ./
  10. # 安装依赖
  11. RUN pnpm install --frozen-lockfile
  12. # Stage 2: Builder
  13. FROM node:18-alpine AS builder
  14. WORKDIR /app
  15. # 安装 pnpm 和 bash
  16. RUN npm install -g pnpm
  17. RUN apk add --no-cache bash
  18. # 复制所有文件
  19. COPY . .
  20. # 复制 node_modules
  21. COPY --from=deps /app/node_modules ./node_modules
  22. # 构建应用
  23. RUN pnpm build
  24. # Stage 3: Runner
  25. FROM node:18-alpine AS runner
  26. WORKDIR /app
  27. ENV NODE_ENV production
  28. # 安装 bash
  29. RUN apk add --no-cache bash
  30. # 创建非 root 用户
  31. RUN addgroup --system --gid 1001 nodejs
  32. RUN adduser --system --uid 1001 nextjs
  33. # 复制必要文件
  34. COPY --from=builder /app/public ./public
  35. COPY --from=builder --chown=nextjs:nodejs /app/.next ./.next
  36. COPY --from=builder /app/node_modules ./node_modules
  37. COPY --from=builder /app/package.json ./package.json
  38. # 设置权限
  39. RUN mkdir -p /app/public/uploads
  40. RUN chown -R nextjs:nodejs /app/public/uploads
  41. # 临时提升权限以允许写入上传目录
  42. USER root
  43. RUN chmod 777 /app/public/uploads
  44. # 设置为非 root 用户
  45. USER nextjs
  46. # 暴露端口
  47. EXPOSE 3000
  48. ENV PORT 3000
  49. # 使用 bash 启动应用
  50. CMD ["/bin/bash", "-c", "node_modules/.bin/next start"]