解決Nginx 配置 proxy_pass 后 返回404問題
一、 Nginx 配置 proxy_pass 后 返回404問題 故障解決和定位
1.1、 問題
在一次生產(chǎn)涉及多次轉(zhuǎn)發(fā)的配置中, 需求是下面的圖:
在配置好了 proxy_pass 之后,請求 www.djx.com 直接返回 404,沒有什么其他的異常。 但是我們直接請求后端 www.baidu.com 是正常響應(yīng)的。這就很怪異的。 看日志請求也是轉(zhuǎn)發(fā)到了 www.baidu.com 的。但是請求響應(yīng)就是404.
1.2、 尋找問題原因
我們的默認(rèn)的 Nginx的 proxy_set_header
配置是
proxy_set_header Host $host;
- 服務(wù)端: 192.168.2.189
- 服務(wù)端1:192.168.1.180 Nginx1
- 服務(wù)端2:192.168.1.90 Nginx2
當(dāng)我們是這個的設(shè)置的時候,當(dāng)?shù)谝粚?Nginx(Nginx1)代理后,我們請求的域名是 www.djx.com ,從這個請求的 header 獲取到的 host 的值是 www.djx.com
, 我們通過 配置
proxy_set_header Host $host;
將 host 的值設(shè)置為轉(zhuǎn)發(fā) 的Host 值,但是請求的域名是 www.baidu.com
, 也就是 header 里面的是 host 字段是 www.djx.com , 請求的域名和 header 里面的 Host 的不一致導(dǎo)致的。
1.3、 proxy_set_header 官方信息
官方文檔
默認(rèn)設(shè)置為
proxy_set_header Host $proxy_host; proxy_set_header Connection close;
1.4、 解決辦法
Host 的值設(shè)置為 $proxy_host
, $proxy_host
的值詳解見下面擴(kuò)展。
proxy_set_header Host $proxy_host;
二、擴(kuò)展 常用的配置
1. $proxy_host
proxy_set_header Host $proxy_host; # 默認(rèn)配置 # 顧名思義,請求頭設(shè)置的為代理后的域名。
示例1:
當(dāng)我們配置了 upstream, 那么$proxy_host 的值就是 upstream 的名字
upstream open-hz8443{ server 10.60.6.184:8000 max_fails=1 fail_timeout=3s weight=10; }
那么這里 $proxy_host 的值就是 open-hz8443。
示例2:
當(dāng)我們沒有配置 upstream, 那么 $proxy_host 的值就是 proxy_pass
后面的地址ip和端口. 10.60.6.184:8000
. 如果是 proxy_pass http://www.djx.com:8000;
那么 $proxy_host 的值就是 www.djx.com:8000
.
location ^~ /wss/v1 { proxy_pass http://10.60.6.184:8000; proxy_set_header Host $proxy_host; proxy_set_header Connection "upgrade"; proxy_set_header Upgrade $http_upgrade; tcp_nodelay on; }
2. $host
proxy_set_header Host $host; # 當(dāng)字段不在請求頭中就無法傳遞了,在這種情況下,可通過設(shè)置Host變量,將需傳遞值賦給Host變量
當(dāng)請求 Header 里 Host 無值的時候,直接拿 server_name 的值進(jìn)行填充。
當(dāng)請求 Header 里 Host 的值的時候,就直接拿 請求 Header 里面的 Host 的值。
3. $host:$proxy_port
proxy_set_header Host $host:$proxy_port; # 服務(wù)器名稱和端口一起通過代理服務(wù)器傳遞,相對上一項(xiàng),多了一個 $proxy_port,這個 $proxy_port 是proxy_pass 里面的那個端口,如果沒有端口,像80 和 443 的話。也是會使用 80 /443 填充, 示例: proxy_pass http://www.baidu.com; $host:$proxy_port = 百度ip:80
4. $http_host
proxy_set_header Host $http_host; # 一個不會變化的“Host”頭請求字段可通過如下方式被傳遞:
當(dāng)請求 Header 里 Host 無值的時候,直接拿 server_name 的值進(jìn)行填充。并加上端口。如果是 80/443 則不加。 其實(shí)就是去 請求url 里面的值。 http://server:port/v1
當(dāng)請求 Header 里 Host 的值的時候,就直接拿 請求 Header 里面的 Host 的值。
示例
- 服務(wù)端: 192.168.2.189
- 服務(wù)端1:192.168.1.180 Nginx1
- 服務(wù)端2:192.168.1.90 Nginx2
基礎(chǔ)配置
192.168.1.180 Nginx1
server{ listen 80; server_name www.djx.com; location / { proxy_pass http://www.baidu.com/; } }
192.168.1.190 Nginx2
server{ listen 80; server_name www.baidu.com; location / { proxy_pass http://192.168.1.80:8080/; } }
** 使用基礎(chǔ)配置 **
也就是
proxy_set_header Host $proxy_host;
那么到 http://192.168.1.80:8080/ header 的值為 www.baidu.com.
** 使用 $host **
也就是
proxy_set_header Host $host;
參考文章:https://cloud.tencent.com/developer/article/1557504
到此這篇關(guān)于Nginx 配置 proxy_pass 后 返回404問題的文章就介紹到這了,更多相關(guān)Nginx 配置 proxy_pass 內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。