2025-09-17 12:12:50 +08:00
|
|
|
|
# 使用官方 Node.js 作为基础镜像;不适用 alpine 版本,这样可以自带git
|
|
|
|
|
|
FROM node:latest AS builder
|
|
|
|
|
|
|
|
|
|
|
|
# 在容器中创建目录
|
2025-09-17 10:37:59 +08:00
|
|
|
|
WORKDIR /app
|
2025-09-17 12:12:50 +08:00
|
|
|
|
|
2025-09-17 10:37:59 +08:00
|
|
|
|
# 安装pnpm
|
2025-09-17 12:12:50 +08:00
|
|
|
|
RUN npm install -g pnpm@10.10.0
|
2025-09-17 10:37:59 +08:00
|
|
|
|
# 设置pnpm镜像源
|
|
|
|
|
|
RUN pnpm config set registry https://registry.npmmirror.com
|
|
|
|
|
|
# 复制依赖文件
|
|
|
|
|
|
COPY package.json pnpm-lock.yaml ./
|
2025-09-17 12:12:50 +08:00
|
|
|
|
# 先复制scripts目录,因为prepare脚本需要用到其中的文件
|
|
|
|
|
|
COPY scripts ./scripts
|
|
|
|
|
|
# 创建src目录,确保create-base-files.js脚本能正常写入文件
|
|
|
|
|
|
RUN mkdir -p src
|
|
|
|
|
|
# 安装依赖
|
|
|
|
|
|
RUN pnpm install
|
|
|
|
|
|
# 复制其余源代码
|
2025-09-17 10:37:59 +08:00
|
|
|
|
COPY . .
|
|
|
|
|
|
# 构建项目
|
|
|
|
|
|
RUN pnpm run build
|
|
|
|
|
|
|
|
|
|
|
|
|
2025-09-17 12:12:50 +08:00
|
|
|
|
# 使用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
|
2025-09-17 10:37:59 +08:00
|
|
|
|
|
2025-09-17 12:12:50 +08:00
|
|
|
|
# 启动nginx
|
|
|
|
|
|
CMD ["nginx", "-g", "daemon off;"]
|