nginx的反向代理upstream失败重试策略详解

 更新时间:2025年09月13日 11:23:21   作者:IT杂人  
文章解析Nginx健康检测参数fail_timeout(标记不可用)与max_fails(失败阈值),并说明重试机制中proxy_next_upstream的配置作用,强调非幂等请求需配合non_idempotent选项,合理设置可避免性能损耗

默认只有被动健康检测

upstream nginxtest{
		#默认使用轮询节点分配请求
		#max_fails默认=1,fail_timeout默认=10s;
		server localhost:8080 weight=5 max_fails=2 fail_timeout=5s;
		server localhost:8082 weight=1 max_fails=2 fail_timeout=5s;
}
	
server {
        listen       18080;
        server_name  localhost;
		
        location / {
			proxy_pass http://nginxtest;
			#proxy_next_upstream  http_500;#默认是error、timeout、幕等请求会重试
            root   html;
            index  index.html index.htm;
        }
}
  • fail_timeout:时间段内计数失败次数
  • max_fails:需要fail_timeout时间段统计的失败次数

两个参数说明:在5秒时间段时,处理请求失败2次,则标记为不可用状态

重要的一点说明:fail_timeout还有一个作用,标记为不可用状态的节点,在等待5秒后,会被尝试分配一个请求过来以便检测是否恢复可用状态!!!

默认重试机制

当我们关闭一个节点时,发现nginx还是正常处理了请求,只是某一次请求等待时间变长了

以下为jmeter一秒一次请求,断开一个节点后,发现请求正常,但某一次明显等待长才返回成功

断开节点后,会是网络错误,所以会重试其他节点处理;

重试策略配置

 location / {
    proxy_pass http://nginxtest;
	proxy_next_upstream error timeout http_404; #off表示不重试
	proxy_next_upstream_timeout 6s;
	proxy_next_upstream_tries 3;
}
  • proxy_next_upstream :指定哪些状态需要重试,默认开启(off显示关闭),但404/500/post等请求不会重试,除非显示指定;
  • proxy_next_upstream_timeout :重试转发超时时间
  • proxy_next_upstream_tries:重试次数

非等幂方法(POST、LOCK、PATCH),请求失败后不会再到其他服务器进行重试。加上non_idempotent选项后,即使是非幂等请求类型(例如POST请求),发生错误后也会重试。 

不合理的重试策略,会减弱nginx的处理能力

另:代理超时配置

location / {
	proxy_connect_timeout 20s;
	proxy_read_timeout 20s;
	proxy_send_timeout 20s;
}
  • proxy_connect_timeout :代理连接超时
  • proxy_read_timeout:代理超时
  • proxy_send_timeout :对应的代理超时

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 详解nginx如何配置HTTPS

    详解nginx如何配置HTTPS

    本篇文章主要介绍了详解nginx如何配置HTTPS,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • 使用nginx正向代理实现访问外网

    使用nginx正向代理实现访问外网

    这篇文章主要介绍了使用nginx正向代理实现让内网主机通过外网主机访问外网,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-12-12
  • centos 7.0 使用Nginx部署flask应用教程

    centos 7.0 使用Nginx部署flask应用教程

    这篇文章主要介绍了centos 7.0 使用Nginx部署flask应用教程,需要的朋友可以参考下
    2017-12-12
  • Nginx配置编写时支持逻辑运算与大小写字母转换的方法

    Nginx配置编写时支持逻辑运算与大小写字母转换的方法

    这篇文章主要介绍了Nginx配置编写时支持逻辑运算与大小写字母转换的方法,其中大小写字母转换是以lower upper case模块来实现,需要的朋友可以参考下
    2016-01-01
  • Nginx服务器下配置个性二级域名及多个域名的实例讲解

    Nginx服务器下配置个性二级域名及多个域名的实例讲解

    这篇文章主要介绍了Nginx服务器下配置个性二级域名及多个域名的实例讲解,注意一下rewrite的写法规则,需要的朋友可以参考下
    2016-01-01
  • Nginx如何配置Http、Https、WS、WSS的方法步骤

    Nginx如何配置Http、Https、WS、WSS的方法步骤

    这篇文章主要介绍了Nginx如何配置Http、Https、WS、WSS的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05
  • nginx访问控制的两种方法

    nginx访问控制的两种方法

    这篇文章主要介绍了关于nginx访问控制的两种方法,一种是基于Basic Auth认证,另一种是基于IP的访问控制,文中介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-03-03
  • Nginx与安全相关的几个配置小结

    Nginx与安全相关的几个配置小结

    Nginx提供了一系列的安全相关参数,可以帮助加固网站安全性,本文主要介绍了Nginx与安全相关的几个配置小结,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • 同一台服务器安装多个Nginx的方法总结

    同一台服务器安装多个Nginx的方法总结

    在同一台服务器上安装多个nginx完全没有问题,但有些地方是需要注意的,这篇文章为大家整理了一些常会遇到的问题以及解决方法,需要的可以参考一下
    2023-08-08
  • Nginx 域名转发的实现

    Nginx 域名转发的实现

    这篇文章主要介绍了Nginx 域名转发的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08

最新评论