Nginx一个Server代理多个Vue项目

Nginx一个Server代理多个Vue项目


一、配置Vue项目

  • 配置vue.config.js的outputDir和publicPath属性

在vue项目的根目录下找到vue.config.js配置文件,打开找到如下代码并修改outputDir和publicPath属性的值。如下代码参考:

module.exports = {
    outputDir: 'console',        // 打包输出的目录名称
    publicPath: '/console',        //index.html文件  资源的引用路径前缀
    // …… 其他配置省略
}

输入如下图:

  • 配置Vue Router的base属性

在vue项目的src目录下找到router.js文件,打开找到如下代码并修改base属性,如果没有此属性可以手动添加。如下代码参考:

const router = new Router({
  mode: 'history',               // 路由模型
  base: '/console/',            // 配置了这个属性后,nginx才能匹配到使用”console“的请求
  routes: constantRouter    // 自定义动态路由配置
})

输入如下图:


二、配置Nginx

在服务器上找到nginx的安装路径(如:/usr/local/nginx)并使用vi命令打开config目录下的nginx.cnf文件,找到需要配置的server进行配置。如下代码参考:

  • 使用root配置vue文件路径
location /cdmt {
    root /usr/local/src/cdmt/dist/cdmt;
    index index.html;
    try_files $uri $uri/ @router;
}

location @router {
    rewrite ^.*$ /cdmt/index.html last;
}

location /console {
    # try_files $uri $uri/ @router;
    root /usr/local/src/cdmt/dist;
    index index.html;
    try_files $uri $uri/ @routeConsole;
}

location @routerConsole {
    rewrite ^.*$ /console/index.html last;
}

  • 使用alias配置vue文件路径
location /cdmt {
    alias /usr/local/src/cdmt/dist/cdmt;
    index index.html;
    try_files $uri $uri/ @router;
}

location @router {
    rewrite ^.*$ /cdmt/index.html last;
}

location /console {
    alias /usr/local/src/cdmt/dist/console;
    index index.html;
    try_files $uri $uri/ @routeConsole;
}

location @routerConsole {
    rewrite ^.*$ /console/index.html last;
}

  • 重启Nginx
#> systemctl restart nginx


三、验证配置

打开浏览器访问console在浏览器地址栏中输入:http://127.0.0.1:9001/console能看到vue的登录界面,说明配置成功,否则请自查原因并解决。


 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值