build: 更新构建配置和Dockerfile
- 将Node.js最低版本要求从22降至20以兼容更多环境 - 在vite配置中添加外部依赖解决构建问题 - 重构Dockerfile,优化构建流程并修复依赖安装问题 - 更新nginx配置和容器启动命令
This commit is contained in:
38
Dockerfile
38
Dockerfile
@@ -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;"]
|
||||||
|
|||||||
@@ -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": {
|
||||||
|
|||||||
@@ -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'],
|
||||||
|
},
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user