时间:2021-05-26
上一篇已经介绍了然后配置web项目;今天由于公司需求,需要在同一域名端口下,部署两个项目;今天花了一上午终于弄好了,选择赶紧做一个笔记。
如何连接阿里云服务器就不在这里说了,请看我以前的文章。
首先需要的效果
http://47.97.244.83/login
http://47.97.244.83/student/login
文件目录
两个项目并列在同一文件夹内。
准备好两个vue的项目
http://47.97.244.83/login:这个不用修改配置直接build就可以。关键是二级域名的vue项目,需要进行一下修改。
首先在config文件夹内的index.js内修改(注意是build内)
// nginx 配置 assetsPublicPath: '/student/',这样确保生产出来的文件,在index.html中都是在student下。
index.html文件修改
添加 <meta base=/student/ >
最后build的index.html文件如下:
<!DOCTYPE html><html><head> <meta base=/student/ > <meta charset=utf-8> <meta http-equiv=X-UA-Compatible content="IE=edge"> <meta name=viewport content="width=device-width,initial-scale=1"><link rel=icon href=./favicon.ico> <title>砺行教育管理系统</title> <link href=/student/static/css/app.26c5efbf7403094b0b351615f215dca8.css rel=stylesheet></head><body> <noscript><strong>对比起程序报错了</strong></noscript> <div id=app></div> <script type=text/javascript src=/student/static/js/manifest.c07ff685ddc74bf39577.js></script> <script type=text/javascript src=/student/static/js/vendor.63945df20397482ff39e.js></script> <script type=text/javascript src=/student/static/js/app.39f0baab8f580b8d4bc2.js></script></body></html>在src/router/index.js文件修改
添加 base: ‘/student/',
Nginx配置修改
server { listen 80; server_name localhost; # root /usr/local/sixiucheng/codes; location / { root /usr/local/sixiucheng/codes/dist; try_files $uri $uri/ @router; index index.html index.htm; } location /student { alias /usr/local/sixiucheng/codes/student/; try_files $uri $uri/ /student/index.html; index index.html index.htm; } location @router { rewrite ^.*$ /index.html last; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } }注意这里的root
一个是全局的一个单个引入,这里需要注意一下当注释掉全局的root时候,需要在二级配置下将root改为alias;如下图
所以此时的配置为
最后一定要注意重启!!!
nginx -s reload注意:如果80端口失败
1.检查下nginx配置,使用nginx -t 看看有无错误信息
2.检查本地防火墙是否开启80
3.如果是云主机,检查安全组是否开放80权限。
题外话
01…刚开始将alias写成root,导致html页面中的css和js一直404;后来百度到加下面一句话,就可以解决问题;但是这样会将所有的js,css引入的位置修改。这里注意一下。
# 解决css,js引入失败 location ~ .*\.(jpg|jpeg|gif|png|ico|css|js|pdf|txt)$ { root /usr/local/sixiucheng/codes; proxy_temp_path /usr/local/sixiucheng/codes; }02…网上还有alias的路径指向,root和alias的区别在于(个人理解,出错希望点出):
location /file/{alias /var/html/file; #这个查找文件的路径直接是/var/html/file}location /file/{root /var/html/file; #这个查找文件的路径应该是/var/html/file/file}到此这篇关于nginx部署多个vue项目的方法示例的文章就介绍到这了,更多相关nginx部署多个vue项目内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
需求nginx下配置多个vue项目举例:blog:https:///blogtest:https:///testvue项目中配置vue-router设置base
背景介绍最近在个人的多个项目部署中遇到这样一个问题,一个域名如何实现多个项目的访问。因为不想自己单独去申请域名证书和域名配置,便想到了这个方案,结合Nginx的
本教程主要讲解的是Vue-CLI3.x脚手架搭建的vue项目,先构建生成dist文件(纯静态应用),然后自动化部署到静态文件服务器Nginx。一、Nginx服务
nginx大家如果没用过那或多或少都应该听过,vue的部署、反向代理、负载均衡nginx都能帮你做到。今天主要说一下nginx负载均衡我们的项目,如下图所示,请
我又来了,今天部署了下vue项目,使用nginx做了代理,这样可以解决跨域的问题,这里做一个简单讲解。1、先看vue项目打包(我这里使用的是vscode开发工具