build: 更新构建配置和Dockerfile

- 将Node.js最低版本要求从22降至20以兼容更多环境
- 在vite配置中添加外部依赖解决构建问题
- 重构Dockerfile,优化构建流程并修复依赖安装问题
- 更新nginx配置和容器启动命令
This commit is contained in:
feige996
2025-09-17 12:12:50 +08:00
parent 4e3942eca8
commit ebd4694aa6
3 changed files with 33 additions and 12 deletions

View File

@@ -1,23 +1,39 @@
# 前端打包 # 使用官方 Node.js 作为基础镜像;不适用 alpine 版本这样可以自带git
FROM node:24 AS build FROM node:latest AS builder
# 在容器中创建目录
WORKDIR /app WORKDIR /app
# 安装pnpm # 安装pnpm
RUN npm install -g pnpm RUN npm install -g pnpm@10.10.0
# 设置pnpm镜像源 # 设置pnpm镜像源
RUN pnpm config set registry https://registry.npmmirror.com RUN pnpm config set registry https://registry.npmmirror.com
# 复制依赖文件 # 复制依赖文件
COPY package.json pnpm-lock.yaml ./ COPY package.json pnpm-lock.yaml ./
# 安装依赖类似npm ci的严格模式 # 先复制scripts目录因为prepare脚本需要用到其中的文件
RUN pnpm install --frozen-lockfile COPY scripts ./scripts
# 复制源代码 # 创建src目录确保create-base-files.js脚本能正常写入文件
RUN mkdir -p src
# 安装依赖
RUN pnpm install
# 复制其余源代码
COPY . . COPY . .
# 构建项目 # 构建项目
RUN pnpm run build RUN pnpm run build
# 内容组装
FROM nginx:1.29.1 AS final
COPY --from=build /app/dist/build/h5 /usr/share/nginx/html # 使用nginx作为服务
COPY ./nginx.conf /etc/nginx/nginx.conf FROM nginx:1.29.1-alpine3.22 AS production-stage
CMD nginx -g "daemon off;" # 将构建好的项目复制到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;"]

View File

@@ -22,7 +22,7 @@
"url-old": "https://github.com/codercup/unibest/issues" "url-old": "https://github.com/codercup/unibest/issues"
}, },
"engines": { "engines": {
"node": ">=22", "node": ">=20",
"pnpm": ">=9" "pnpm": ">=9"
}, },
"scripts": { "scripts": {

View File

@@ -184,6 +184,11 @@ export default defineConfig(({ command, mode }) => {
target: 'es6', target: 'es6',
// 开发环境不用压缩 // 开发环境不用压缩
minify: mode === 'development' ? false : 'esbuild', minify: mode === 'development' ? false : 'esbuild',
// 添加外部依赖解决Docker构建中的依赖解析问题
rollupOptions: {
// 前4个由 @tanstack/vue-query 引起的std-env 由 @uni-helper/uni-env 引起的
external: ['@tanstack/query-core', 'vue-demi', '@vue/devtools-api', '@tanstack/match-sorter-utils', 'std-env'],
},
}, },
}) })
}) })