Vue ant打包服务器-并配置【nginx子路径+linux环境】跨域解决+jenkins自动部署

1.起初

害!最近把之前用JQ做的前端页面,换成了用vue写,所以再将vue项目放在服务器上运行时,就折腾了一下,稍微麻烦了点,索性就记录下把

2.环境

a.前端是用Vue Ant Design(版本2.0)
b.服务器Alibaba Cloud Linux release 3 (Soaring Falcon)
c.接口Python的Flask / django
d.Jenkins

3.准备

a.首页将你Vue的项目先打包把 (虽然现在很多都自动打包了)
打包前需要改一下配置文件,为了能在服务器中访问静态文件css/js/ico等:
PUBLIC_PATH=/ 改成👇

PUBLIC_PATH=./ 注意多了个"." , .env配置文件是全局的
在这里插入图片描述
b.其他版本的可以在vue.config.js文件里面改👇Vue ant改这个无效在这里插入图片描述
c.再打包命令 npm run build

在这里插入图片描述

4.服务器配置

a.打好包后,可以压缩一下,也可以不压缩,后面将dist打包文件提交到Git上
b.下面是手动上传到服务器(rz导入命令需要yum安装一下,自行百度)
(导入成功后-记得解压 unzip dist.zip (没有unzip用yum安装))在这里插入图片描述
注意用pwd,获取git上传文件,或者手动上传的路径
.
C.Nginx配置了(不知道nginx.conf文件位置的用find / -name nginx.conf 全局搜索)
如果你也是HTTPS则下滑到https的server{}
再配置一个location在这里插入图片描述
配置完成后记得保存
然后重启nginx命令:/usr/local/nginx/sbin/nginx -s reload

5.访问

a.打开浏览器,输入服务器ip域名+子路径(后面的#/login是自动追溯的html)
在这里插入图片描述

##5.1:将Vue前端部署到服务器的Nginx以后,浏览器访问资源时就会产生跨域问题,随后使用gateway做了网关配置。配置完成后使用谷歌浏览器访问资源时控制台报错strict-origin-when-cross-origin
.
##5.2:因为我这里是采用了https和http混同模式,为了解决跨域问题,所以vue需要更改
在这里插入图片描述
##5.3:接口需要兼容跨域问题,CORS针对中前端或VUE需要
在这里插入图片描述

##6.Jenkins部署

代码提交到git后,触发jenkins自动构建(但不要跟下图一样改成Jenkins的仓库路径了)
在这里插入图片描述
因为这里会遇到一个问题,就是nginx找不到jenkins放在服务器中的vue项目地址,所以我们需要让jenkins帮我们剪切到nginx目录下的html文件中
在这里插入图片描述
(注意,nginx的vue路径要改回来,改成剪切到的目录路径)

##7.Git触发Jenkins部署新文件到linux配置

在这里插入图片描述
在这里插入图片描述

##8.结尾

1.后续就是Vue打包完后,再手动去commit提交/push到git上
2.git会自动触发调用jenkins的构建接口,jenkins再去完成将旧文件代码给替换掉的工作
3.URL = jenkins的项目路径
4.HOOK密码 = jenkins配置中生成的
5.具体详情的步骤可以自行百度一下,很简单
在这里插入图片描述

!结束了,大致是这样,每个人的环境不同,只能说是参考, 折腾的最久的就是读取静态文件的问题,需要找到对于前端框架的全局配置文件


<think>嗯,用户想了解如何将Vue3与Element Plus构建的项目进行打包部署上线。我需要整理一下相关的步骤和可能遇到的问题。首先,根据引用中的信息,比如引用3提到了npm run build:prod来打包正式环境,所以应该先确认打包命令。然后,部署Nginx服务器,引用2和引用4都提到了使用Docker安装Nginx或者直接配置Nginx,这可能是一个常见的做法。 接下来,用户可能遇到的问题,比如打包后的静态文件路径问题,需要设置publicPath。引用3中提到了部署到生产环境时可能遇到的路径问题,所以需要调整vue.config.js中的publicPath。另外,路由模式如果是history的话,Nginx需要配置重定向到index.html,避免出现404错误,引用4中也提到了路由配置的问题。 另外,用户可能遇到的错误,比如引用1中的elementPlus组件库报错,上传组件的问题,可能需要检查组件版本或配置。还有引用5提到的图标乱码问题,可能是sass-loader版本或字体文件加载的问题,需要确保正确配置字体和图标资源。 可能还需要考虑问题,在开发环境中通过代理解决,但生产环境中需要Nginx反向代理后端API,引用4中的例是Django后端,但同样适用于其他后端服务。 最后,优化方面,比如开启Gzip压缩、配置缓存策略,这些都能提升加载速度。还有自动部署,可能用到CI/CD工具,但用户的问题可能更关注基本部署步骤,所以这部分可以作为高级实践提到。 需要确保步骤清晰,分阶段讲解:打包配置部署Nginx、常见问题解决、优化建议。同时引用相关的引用资料来支持每个步骤,比如引用3的打包命令,引用2和4的Nginx配置,引用1和5的问题解决方法。可能还需要提醒用户测试打包后的文件,使用serve或其他静态服务器进行本地验证,确保没有问题再部署到线上。</think>### Vue3 + Element Plus 项目打包部署上线指南 #### 一、打包配置与生成静态文件 1. **环境准备** 确保项目依赖安装完整,运行 `npm install` 或 `yarn install`,检查 `package.json` 中 `element-plus` 和 `sass-loader` 版本兼容性[^5]。 2. **打包命令** 使用以下命令生成生产环境静态文件: ```bash npm run build:prod # 或 yarn build:prod ``` 生成文件默认在 `dist/` 目录下[^3]。 3. **路径配置** 在 `vue.config.js` 中设置 `publicPath` 解决资源路径问题: ```javascript module.exports = { publicPath: process.env.NODE_ENV === 'production' ? './' : '/' } ``` #### 二、部署Nginx服务器 1. **Nginx基础配置** 将 `dist/` 目录上传至服务器配置Nginx指向静态文件: ```nginx server { listen 80; server_name your_domain.com; root /path/to/dist; index index.html; location / { try_files $uri $uri/ /index.html; # 支持Vue路由history模式[^4] } # 反向代理后端API location /api { proxy_pass http://backend_server:port; proxy_set_header Host $host; } } ``` 2. **Docker部署(可选)** 通过Docker容器化部署Nginx,参考引用[2]的容器化实践: ```dockerfile FROM nginx:alpine COPY dist/ /usr/share/nginx/html COPY nginx.conf /etc/nginx/conf.d/default.conf ``` #### 三、常见问题解决 1. **Element Plus组件报错** 若出现类似 `t.upload.addEventListener is not a function` 错误,检查 `el-upload` 组件是否在非浏览器环境(如SSR)被调用,需调整组件引入方式[^1]。 2. **图标乱码问题** 确保 `sass-loader` 和 `sass` 版本与Element Plus兼容,打包后验证字体文件路径是否正确。 3. **问题** 生产环境通过Nginx反向代理后端服务,避免限制。 #### 四、优化建议 1. **开启Gzip压缩** 在Nginx配置Gzip减少资源体积: ```nginx gzip on; gzip_types text/plain text/css application/json application/javascript; ``` 2. **静态资源缓存** 添加缓存头提升加载速度: ```nginx location /assets { expires 1y; add_header Cache-Control "public"; } ``` 3. **自动部署** 结合CI/CD工具(如GitHub Actions、Jenkins)实现自动化构建与发布[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值