# 使用官方 Node.js 作为基础镜像;不适用 alpine 版本,这样可以自带git FROM node:latest AS builder # 在容器中创建目录 WORKDIR /app # 安装pnpm RUN npm install -g pnpm@10.10.0 # 设置pnpm镜像源 RUN pnpm config set registry https://registry.npmmirror.com # 复制依赖文件 COPY package.json pnpm-lock.yaml ./ # 先复制scripts目录,因为prepare脚本需要用到其中的文件 COPY scripts ./scripts # 创建src目录,确保create-base-files.js脚本能正常写入文件 RUN mkdir -p src # 安装依赖 RUN pnpm install # 复制其余源代码 COPY . . # 构建项目 RUN pnpm run build # 使用nginx作为服务 FROM nginx:1.29.1-alpine3.22 AS production-stage # 将构建好的项目复制到nginx下 COPY --from=builder /app/dist/build/h5 /usr/share/nginx/html # 将默认的nginx配置文件替换为我们自定义的nginx配置文件 COPY nginx.conf /etc/nginx/conf.d/default.conf # 暴露端口 EXPOSE 80 EXPOSE 443 # 启动nginx CMD ["nginx", "-g", "daemon off;"]