主頁 > 知識庫 > 淺談nginx反向代理中神奇的斜線

淺談nginx反向代理中神奇的斜線

熱門標簽:臨汾電銷機器人費用 七大洲地圖標注 福州呼叫中心外呼系統(tǒng)哪家好 地圖標注w是什么方向 400電話申請找哪家公司 新鄉(xiāng)人工智能電話機器人加盟 地圖標注需要提交啥資料入駐 昆明外呼系統(tǒng) 河南省鄭州市地圖標注

在進行nginx反向代理配置的時候,location和proxy_pass中的斜線會造成各種困擾,有時候多一個或少一個斜線,就會造成完全不同的結(jié)果,所以特地將location和proxy_pass后有無斜線的情況進行了排列組合,進行了一次完整的測試,找出原理,以提高姿勢水平~

〇. 環(huán)境信息

兩臺nginx服務(wù)器

nginx A: 192.168.1.48

nginx B: 192.168.1.56

一. 測試方法

在nginx A中配置不同的規(guī)則,然后請求nginx A: http://192.168.1.48/foo/api

觀察nginx B收到的請求,具體操作是查看日志中的$request字段

二. 測試過程及結(jié)果

案例1

nginx A配置:

location /foo/ {
  proxy_pass http://192.168.1.56/;
}

nginx B收到的請求:/api

案例2

nginx A配置:

location /foo/ {
  proxy_pass http://192.168.1.56/;
}

nginx B收到的請求://api

案例3

nginx A配置:

location /foo/ {
  proxy_pass http://192.168.1.56/;
}

nginx B收到的請求:/foo/api

案例4

nginx A配置:

location /foo/ {
  proxy_pass http://192.168.1.56/;
}

nginx B收到的請求:/foo/api

案例5

nginx A配置:

location /foo/ {
  proxy_pass http://192.168.1.56/bar/;
}

nginx B收到的請求:/bar/api

案例6

nginx A配置:

location /foo {
  proxy_pass http://192.168.1.56/bar/;
}

nginx B收到的請求:/bar//api

案例7

nginx A配置:

location /foo/ {
  proxy_pass http://192.168.1.56/bar;
}

nginx B收到的請求:/barapi

案例8

nginx A配置:

location /foo {
  proxy_pass http://192.168.1.56/bar;
}

nginx B收到的請求:/bar/api

看到這里是不是都暈了呢,其實是有規(guī)律的

現(xiàn)在把這些案例按表格排列起來,結(jié)果表示nginx B收到的請求

表一

案例 location proxy_pass 結(jié)果
1 /foo/ http://192.168.1.48/ /api
2 /foo http://192.168.1.48/ //api
3 /foo/ http://192.168.1.48 /foo/api
4 /foo http://192.168.1.48 /foo/api

表二

案例 location proxy_pass 結(jié)果
5 /foo/ http://192.168.1.48/bar/ /bar/api
6 /foo http://192.168.1.48/bar/ /bar//api
7 /foo/ http://192.168.1.48/bar /barapi
8 /foo http://192.168.1.48/bar /bar/api

三. 解析

原請求路徑:本文中統(tǒng)一為 "/foo/api"

location: 上面表格中的location列

proxy_pass:上面表格中的proxy_pass列

新請求路徑:nginx將原請求路徑處理過后的字符串

重點對 proxy_pass 進行分析,可以分為3種形式

然后按照ip:port后是否接了字符串歸為2類,"/"也是字符串,因此1歸為一類,2、3歸為一類,下面對這兩類情況進行說明

當 proxy_pass 的 ip:port 后未接字符串的時候,nginx 會將原請求路徑原封不動地轉(zhuǎn)交給下一站 nginx,如案例3和4

當 proxy_pass 的 ip:port 后接了字符串的時候,nginx 會將 location 從 原請求路徑 中剔除,再將剩余的字符串拼接到 proxy_pass 后生成 新請求路徑,然后將 新請求路徑 轉(zhuǎn)交給下一站nginx(上面一種情況實際上和這個是一樣的,只不過剔除的字符串是空串~~)

舉個最讓人疑惑的例子:案例7。proxy_pass 的 ip:port 后接了字符串 "/bar",因此將 location:"/foo/" 從 原請求路徑:"/foo/api" 中剔除,變?yōu)?api",再將"api"拼接到proxy_pass: http://192.168.1.48/bar 后生成了新請求url:" http://192.168.1.48/barapi ",因此下一站的nginx收到的請求就是 "/barapi"。

案例6:proxy_pass 的 ip:port 后接了字符串 "/bar/",因此將 location:"/foo" 從 原請求路徑 "/foo/api" 中剔除,變?yōu)?"/api",再將 "/api" 拼接到proxy_pass: http://192.168.1.48/bar/ 后生成了 新請求路徑:" http://192.168.1.48/bar//api ",因此下一站的nginx收到的請求就是 /bar//api。

其它的案例都可以以此類推,現(xiàn)在終于搞明白了,再也不用一頭霧水。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標簽:鎮(zhèn)江 四川 岳陽 股票 臨沂 紅河 烏海

巨人網(wǎng)絡(luò)通訊聲明:本文標題《淺談nginx反向代理中神奇的斜線》,本文關(guān)鍵詞  淺談,nginx,反向,代理,中,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《淺談nginx反向代理中神奇的斜線》相關(guān)的同類信息!
  • 本頁收集關(guān)于淺談nginx反向代理中神奇的斜線的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章