Dockerfile.prod 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  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 --no-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. ENV JWT_SECRET=${JWT_SECRET}
  29. ENV MONGODB_URI=${MONGODB_URI}
  30. # 安装 bash
  31. RUN apk add --no-cache bash
  32. # 创建非 root 用户
  33. # RUN addgroup --system --gid 1001 nodejs
  34. # RUN adduser --system --uid 1001 nextjs
  35. # 创建非 root 用户和组
  36. RUN addgroup -S -g 1001 nodejs && adduser -S -u 1001 -G nodejs nextjs
  37. # 复制必要文件
  38. COPY --from=builder /app/public ./public
  39. COPY --from=builder --chown=nextjs:nodejs /app/.next ./.next
  40. COPY --from=builder /app/node_modules ./node_modules
  41. COPY --from=builder /app/package.json ./package.json
  42. # 设置权限
  43. RUN mkdir -p /app/public/uploads
  44. RUN chown -R nextjs:nodejs /app/public
  45. RUN chown -R nextjs:nodejs /app/public/uploads
  46. # RUN chmod 2775 /app/public/uploads
  47. # RUN usermod -a -G nodejs nextjs
  48. # 临时提升权限以允许写入上传目录
  49. USER root
  50. RUN chmod 777 /app/public/uploads
  51. # 设置 umask
  52. # RUN echo "umask 0002" >> /home/nextjs/.bashrc
  53. # 设置为非 root 用户
  54. USER nextjs
  55. # 暴露端口
  56. EXPOSE 3000
  57. ENV PORT 3000
  58. # 使用 bash 启动应用
  59. CMD ["/bin/bash", "-c", "node_modules/.bin/next start"]