mirror of
https://github.com/vbenjs/vue-vben-admin.git
synced 2025-01-24 02:00:25 +08:00
dcbe5510d4
* feat: update nginx.conf 使用固定编译入口可能导致浏览器使用缓存js文件,而此配置可以解决 * feat: 更新docker打包逻辑: 原本固定的entry是为了方便替换环境变量,同时在nginx配置内让每次获取js等资源都不走缓存。这样的问题是首次打开会很慢。 因此本次使用的解决方案,回归vben原本的hash+timestamp的入口文件名,但是在环境变量替换的时候使用模糊匹配。 大家有类似需要可以参考环境变量的方式做 单镜像打包多环境的适配。
26 lines
1.2 KiB
Docker
26 lines
1.2 KiB
Docker
# node 构建
|
||
FROM node:16-alpine as build-stage
|
||
# 署名
|
||
MAINTAINER Adoin 'adoin@qq.com'
|
||
WORKDIR /app
|
||
COPY . ./
|
||
# 设置 node 阿里镜像
|
||
RUN npm config set registry https://registry.npmmirror.com
|
||
# 设置--max-old-space-size
|
||
ENV NODE_OPTIONS=--max-old-space-size=16384
|
||
# 设置阿里镜像、pnpm、依赖、编译
|
||
RUN npm install pnpm -g && \
|
||
pnpm install --frozen-lockfile && \
|
||
pnpm build:docker
|
||
# node部分结束
|
||
RUN echo "🎉 编 🎉 译 🎉 成 🎉 功 🎉"
|
||
# nginx 部署
|
||
FROM nginx:1.23.3-alpine as production-stage
|
||
COPY --from=build-stage /app/dist /usr/share/nginx/html/dist
|
||
COPY --from=build-stage /app/nginx.conf /etc/nginx/nginx.conf
|
||
EXPOSE 80
|
||
## 将/usr/share/nginx/html/dist/assets/index.js 和/usr/share/nginx/html/dist/_app.config.js中的"$vg_base_url"替换为环境变量中的VG_BASE_URL,$vg_sub_domain 替换成VG_SUB_DOMAIN,$vg_default_user替换成VG_DEFAULT_USER,$vg_default_password替换成VG_DEFAULT_PASSWORD 而后启动nginx
|
||
CMD sed -i "s|__vg_base_url|$VG_BASE_URL|g" /usr/share/nginx/html/dist/assets/entry/index-*.js /usr/share/nginx/html/dist/_app.config.js && \
|
||
nginx -g 'daemon off;'
|
||
RUN echo "🎉 架 🎉 设 🎉 成 🎉 功 🎉"
|