Nginx同一端口部署多個前后端分離的vue項目完整步驟
前言
要用nginx容器部署多個前端項目可以采用監(jiān)聽端口,和基于location配置兩種方法,
我的nginx是使用docker部署的,啟動的時候沒有開多余的端口,所以采用location配置
一個server下根據(jù)根路徑不同分別代理訪問不同項目。
下面操練起來,問:把大象放冰箱?總共需要幾步:三步!
第一步:Nginx 相關(guān)位置代碼
worker_processes 1;
events {
worker_connections 1024;
}
http {
client_max_body_size 100m;
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
listen 80;
server_name localhost;
charset utf-8;
#項目一,同過ip:80直接訪問
location / {
root /home/ruoyi-ui/dist; #dist文件的位置(根據(jù)自己dist包放置的位置決定)
try_files $uri $uri/ /index.html;
index index.html index.htm;
}
#項目二,同過ip:80/project直接訪問
location /project {
alias /home/zero/dist/;#注意第二個項目路徑是alias不是root,通常最佳實際是配置一個項目的根root,其他的文件夾則使用alias,畢竟alias更加靈活
try_files $uri $uri/ /project/index.html;
index index.html;
}
#第一個項目(前后端分離)反向代理來解決跨域問題
location /prod-api/ {
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
#后端服務(wù)端口地址:
proxy_pass http://10.10.11.79:8080/;
}
#第二個項目(前后端分離)反向代理來解決跨域問題,要與第二個項目vue里面跨域的配置一致,沒有跨域問題可以不配置
location /zero-api/ {
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
#后端服務(wù)端口地址:
proxy_pass http://10.10.11.79:8083/;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}
訪問的時候是ip:端口號/+你配置的路徑:第一個路徑時候/,第二個路徑是/project
主要是兩個地方:
1.第二個local 后面/project 這個名字要與vue項目中index.js ,vue.config.js配置里面的名稱要一樣
2.跨域的問題第四個local中l(wèi)ocation /zero-api/ 這個名字要與vue項目中vue.config.js文件中的跨域那個地方的配置要一致。
第二步:Vue 項目配置文件設(shè)置
1.修改index.js
修改路由,在src目錄下找到reouter目錄,添加base屬性:
base: '/project',
這個地方的名字需要與 nginx.conf 中第二個項目location的/后面的路徑名稱一致。

2. 修改vue.config.js
修改根目錄下的vue.config.js的publicPath路徑:
module.exports = {
publicPath: "/project'",
}
這個地方的名字需要與 nginx.conf 中第二個項目location的/后面的路徑名稱一致。
3. 處理前后端分離跨域問題
沒有跨域需求可以不配,現(xiàn)在都是前后端分離了,用nginx分別代理前端和后端微服務(wù),解決跨越問題。修改vue.config.js:
devServer: {
port: 80, //本地項目端口
proxy: {
"/zero-api": { // 這個意思是:原先以 /zero-api 開頭的請求
target: 'http://10.10.11.79:8083', // 凡是以 /zero-api 開頭的請求,通通請求這個服務(wù)器
changeOrigin: true, // 允許跨域
}
}
},
/zero-api 要與nginx 里面那個反向代理里面那個zero-api一致。
第三步:部署
修改nginx配置文件nginx.conf,把第二個vue項目打包放到目錄中/home/zero/dist,重啟nginx。
總結(jié)
到此這篇關(guān)于Nginx同一端口部署多個前后端分離的vue項目的文章就介紹到這了,更多相關(guān)Nginx部署多個前后端分離vue項目內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue+element-ui表格自定義列模版的實現(xiàn)
本文主要介紹了vue+element-ui表格自定義列模版的實現(xiàn),通過插槽完美解決了element-ui表格自定義列模版的問題,具有一定的參考價值,感興趣的可以了解一下2024-05-05
Vue3 Element Plus表格默認(rèn)顯示一行實例
這篇文章主要介紹了Vue3 Element Plus表格默認(rèn)顯示一行實例,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-07-07
mockjs+vue頁面直接展示數(shù)據(jù)的方法
這篇文章主要介紹了mockjs+vue頁面直接展示數(shù)據(jù)的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12

