Dockerfile.prod 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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. # 创建 uploads 目录并设置权限
  39. # RUN mkdir -p /app/public/uploads && chown -R nextjs:nodejs /app/public && chown -R nextjs:nodejs /app/public/uploads
  40. # 设置权限
  41. RUN mkdir -p /app/public/uploads && \
  42. chown -R nextjs:nodejs /app && \
  43. chmod -R 755 /app/public && \
  44. chmod 755 /app/public/uploads
  45. # 再次确认 uploads 目录的权限
  46. RUN chown nextjs:nodejs /app/public/uploads && \
  47. chmod 755 /app/public/uploads
  48. # 设置为非 root 用户
  49. USER nextjs
  50. # 暴露端口
  51. EXPOSE 3000
  52. ENV PORT 3000
  53. # 使用 bash 启动应用
  54. CMD ["/bin/bash", "-c", "node_modules/.bin/next start"]