记录一次 Nginx 配置 proxy_pass 后 返回404问题

一、 Nginx 配置 proxy_pass 后 返回404问题 故障解决和定位
1.1、 问题

在一次生产涉及多次转发的配置中, 需求是下面的图: image
在配置好了 proxy_pass 之后,请求 www.djx.com 直接返回 404,没有什么其他的异常。 但是我们直接请求后端 www.baidu.com 是正常响应的。这就很怪异的。 看日志请求也是转发到了 www.baidu.com 的。但是请求响应就是404.
1.2、 寻找问题原因

我们的默认的 Nginx的 proxy_set_header 配置是

proxy_set_header Host $host;

服务端: 192.168.2.189
服务端1:192.168.1.180 Nginx1
服务端2:192.168.1.90 Nginx2

image

当我们是这个的设置的时候,当第一层 Nginx(Nginx1)代理后,我们请求的域名是 www.djx.com ,从这个请求的 header 获取到的 host 的值是 www.djx.com, 我们通过 配置

proxy_set_header Host $host;

将 host 的值设置为转发 的Host 值,但是请求的域名是 www.baidu.com , 也就是 header 里面的是 host 字段是 www.djx.com , 请求的域名和 header 里面的 Host 的不一致导致的。

image
1.3、 proxy_set_header 官方信息

官方文档

默认设置为

proxy_set_header Host $proxy_host;
proxy_set_header Connection close;

1.4、 解决办法

Host 的值设置为 $proxy_host, $proxy_host 的值详解见下面扩展。

proxy_set_header Host $proxy_host;

二、扩展 常用的配置

  1. $proxy_host

proxy_set_header Host $proxy_host;

默认配置

顾名思义,请求头设置的为代理后的域名。

示例1:
当我们配置了 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:
当我们没有配置 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;

}

  1. $host

proxy_set_header Host $host;

当字段不在请求头中就无法传递了,在这种情况下,可通过设置Host变量,将需传递值赋给Host变量

当请求 Header 里 Host 无值的时候,直接拿 server_name 的值进行填充。

当请求 Header 里 Host 的值的时候,就直接拿 请求 Header 里面的 Host 的值。
3. h o s t : host: host:proxy_port

proxy_set_header Host h o s t : host: host:proxy_port;

服务器名称和端口一起通过代理服务器传递,相对上一项,多了一个 $proxy_port,这个 $proxy_port 是proxy_pass 里面的那个端口,如果没有端口,像80 和 443 的话。也是会使用 80 /443 填充,

示例:
proxy_pass http://www.baidu.com;

h o s t : host: host:proxy_port = 百度ip:80

  1. $http_host

proxy_set_header Host $http_host;

一个不会变化的“Host”头请求字段可通过如下方式被传递:

当请求 Header 里 Host 无值的时候,直接拿 server_name 的值进行填充。并加上端口。如果是 80/443 则不加。 其实就是去 请求url 里面的值。 http://server:port/v1

当请求 Header 里 Host 的值的时候,就直接拿 请求 Header 里面的 Host 的值。
示例

服务端: 192.168.2.189
服务端1:192.168.1.180 Nginx1
服务端2:192.168.1.90 Nginx2

image

基础配置
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/;
}

}

** 使用基础配置 **
也就是

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

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
出现"nginx proxy_pass 404"错误通常是由于配置问题导致的。要解决这个问题,需要检查以下几个方面: 1. 确保代理目标的服务器正在运行并且可以通过指定的URL进行访问。例如,在给定的示例中,确保www.baidu.com服务器是可访问的。 2. 检查proxy_pass指令的配置。在给定的示例中,proxy_pass指令是将请求代理到http://www.baidu.com/。确保该URL正确并且不存在拼写错误。 3. 确保代理目标服务器上的相应路径和资源存在。在给定的示例中,如果代理目标服务器上不存在相应的路径,就会出现404错误。确保代理目标服务器上存在正确的路径和资源。 4. 检查Nginx服务器的日志文件,查看是否有其他错误消息或警告。日志文件可以提供有关问题的更多详细信息。 总结起来,要解决"nginx proxy_pass 404"错误,您需要确保代理目标服务器的可访问性,检查proxy_pass指令的配置,确保代理目标服务器上存在正确的路径和资源,并查看Nginx服务器的日志文件以获取更多信息。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [nginx配置proxy_pass之后返回404问题Nginx host相关变量说明](https://blog.csdn.net/eaglecolin/article/details/125538212)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [记录一次 Nginx 配置 proxy_pass返回404问题](https://blog.csdn.net/qq_40848737/article/details/112213079)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值