新项目:同一域名下部署多个vue项目,
根目录vue项目不需要按下面的方式进行打包部署
https://www.xxxx.com/
下面三个项目以二级目录部署
https://www.xxxx.com/hmange
https://www.xxxx.com/api
https://www.xxxx.com/restful
以上链接不可用,作为示例,不要点击。此方法适用于多vue项目,二级目录部署
server {
listen 80;
server_name www.bytedit.com;
access_log /var/log/nginx/bytedit.access.log;
error_log /var/log/nginx/bytedit.error.log;
location ^~/ {
alias /usr/local/nginx/html/front/;
try_files $uri $uri/ /index.html;
index index.html;
}
location ^~/hmanage {
alias /usr/local/nginx/html/hmanage/;
try_files $uri $uri/ /hmanage/index.html;
index index.html;
}
location ^~/restful {
alias /usr/local/nginx/html/restful/;
try_files $uri $uri/ /restful/index.html;
index index.html;
}
location ^~/api {
alias /usr/local/nginx/html/api/;
try_files $uri $uri/ /api/index.html;
index index.html;
}
location /profile/image {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://127.0.0.1:8081/profile/image;
}
}
前端在打包静态文件的时候需要进行以下修改:
1、在vue.config.js 配置文件中,publicPath 和 outputDir 都改为 '/子目录名/'。
2、入口文件 index.html 的head 标签内加入
新增 <meta base="/子目录名/">
vim public/index.html 新增 <meta base="/hmanage/">
3、vue-router 路由文件的配置,填写二级目录
新增 base: '/子目录名/',
vim src/router/index.js
新增 base:'/hmanage/',
4、nginx 配置以及前端资源根目录
location ^~/hmanage {
alias /usr/local/nginx/html/hmanage/;
try_files $uri $uri/ /hmanage/index.html;
index index.html;
}
转 : https://zhuanlan.zhihu.com/p/242758284