nginx - 上游服务器交互出错的处理

nginx上游下游说明

当与上游的交互出现错误时,Nginx并不想立刻认为这个请求处理失败,而是试图多给上游服务器一些机会,可以重新向这台或者另一台上游服务器发起连接、发送请求、接受响应,以避免网络故障。ngx_http_upstream_next方法在结束请求之前,会检查ngx_peer_connection_t结构体的tries成员,tries成员会初始化为每个连接的最大重试次数,每当这个连接与上游服务器出现错误时,就会把tries减1。在出错时,ngx_http_upstream_next会首先检查tries,如果它减到0,才会真正的调用ngx_http_upstream_finalize_request方法结束请求,否则不会结束请求,而是调用ngx_http_upstream_connect方法重新向上游发起请求。

实践中的配置

nginx可以通过设置max_fails和fail_timeout对节点失败的尝试次数和失效时间进行设置。max_fails为最大尝试失败次数;fail_timeout为失效时间,在达到最大尝试次数后,在fail_timeout时间范围内节点被置为失效,除非所有节点都失效,否则该时间内,节点不进行恢复,当超过失效时间(或者所有节点都失效)后,该节点重新置为有效,重新探测。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值