濮阳杆衣贸易有限公司

主頁 > 知識庫 > 詳解Nginx proxy_pass的一個/斜杠引發(fā)的血案

詳解Nginx proxy_pass的一個/斜杠引發(fā)的血案

熱門標(biāo)簽:智能電銷機器人真的有用么 撫州市城區(qū)地圖標(biāo)注 中國地圖標(biāo)注上各個省 高德地圖標(biāo)注足跡怎么打標(biāo) 電銷智能機器人試用 新鄉(xiāng)牧野400電話申請 激光標(biāo)記地圖標(biāo)注 百度地圖底圖標(biāo)注 企業(yè)辦理400電話收費標(biāo)準(zhǔn)

背景

一個nginx的server模塊下需要proxy到兩個server,所以就通過location的不同路徑來區(qū)分轉(zhuǎn)發(fā)到不同的服務(wù)器上。

一開始是這么寫的

location / {
   proxy_pass http://server1/;
}

location /index {
   proxy_pass http://server2/;
}

但是忘記了server1上有個服務(wù)路徑是/indexNew,結(jié)果就被proxy到了server1,出現(xiàn)404問題,然后緊急修改配置如下:

location /indexNew {
   proxy_pass http://server1/;
}

location / {
   proxy_pass http://server1/;
}

location /index {
   proxy_pass http://server2/;
}

問題現(xiàn)象

結(jié)果請求是到了server1了,但是錯誤變成,POST not supported

{
	"status": 500,
	"message": "http://172.28.72.117/-Request method 'POST' not supported",
	"result": {}
}

這是當(dāng)時應(yīng)用的返回錯誤,查看nginx也沒有報錯,很奇怪,看了代碼里/indexNew的確是POST方法啊,為啥報錯不支持呢。

首先這里補充下location各種寫法在nginx里的匹配順序:

分析

nginx日志也沒有報錯,就嘗試抓包,從nginx到應(yīng)用的包

通過tcpdump命令抓包

tcpdump -w dataAll_normal.pcap -i eth0 -s0 port 8888

類似上述命令抓包,然后通過wireshark看,發(fā)現(xiàn)壓根沒搜索到/indexNew相關(guān)的http流量包。

嘗試修改location如下

location /indexNew {
   proxy_pass http://server1;
}

location / {
   proxy_pass http://server1/;
}

location /index {
   proxy_pass http://server2/;
}

區(qū)別僅僅在于/indexNew的proxy_pass最后一個/斜杠去掉了,繼續(xù)抓包,發(fā)現(xiàn)可以搜索到/indexNew的包

說明此次修改正確了。

繼續(xù)改回錯誤的,嘗試抓包,還是沒能搜索到/indexNew的包,然后通過IDE遠(yuǎn)程debug應(yīng)用

發(fā)現(xiàn)到了應(yīng)用里的URL壓根也沒有/indexNew,那當(dāng)然在wireshark包里搜不到了。。。

是因為nginx轉(zhuǎn)發(fā)應(yīng)用的時候,訪問路徑就只有 / 了。

而工程中請求路徑為 / 的接口的確是GET方法

詳細(xì)看下location中proxy_pass的語法,的確是這樣,proxy_pass最后有/,會把匹配location里的路徑去掉,截取后面的URL PATH進(jìn)行轉(zhuǎn)發(fā)。

所以這里一定要注意proxy_pass最后一個/的含義作用,要慎用,它會改變路徑請求信息,而不是100%的信息轉(zhuǎn)發(fā)。

到此這篇關(guān)于詳解Nginx proxy_pass的一個/斜杠引發(fā)的血案的文章就介紹到這了,更多相關(guān)Nginx proxy_pass斜杠內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

標(biāo)簽:辛集 南通 臨汾 忻州 邯鄲 延安 海西 西安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Nginx proxy_pass的一個/斜杠引發(fā)的血案》,本文關(guān)鍵詞  詳解,Nginx,proxy,pass,的,一個,;如發(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 proxy_pass的一個/斜杠引發(fā)的血案》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解Nginx proxy_pass的一個/斜杠引發(fā)的血案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    谢通门县| 莱西市| 寿阳县| 平远县| 当阳市| 平安县| 科尔| 思南县| 尉氏县| 商河县| 大港区| 松潘县| 洛阳市| 临海市| 衡阳市| 舟山市| 井研县| 杭锦后旗| 巴南区| 屏东市| 桂阳县| 米林县| 阳曲县| 怀仁县| 饶阳县| 迁西县| 永靖县| 长顺县| 海淀区| 饶阳县| 浦县| 赤峰市| 恭城| 宁明县| 佛冈县| 漠河县| 乌拉特中旗| 丹东市| 济宁市| 紫云| 江山市|