nginx大量499分析

源于一个客户端同事说,客户端突然发现有大量的超时请求,让我们查一下,下面是检查情况:

nginxaccess.log中发现大量的499状态码,从网上查找资料分析有两种可能:

1.客户端主动断开连接

2.服务端响应超时造成客户端连接中断

上面两种可能归根接地还是一种情况,客户端主动断开了连接,至于是服务端响应超时还是客户端连接等其他原因有待检查

首先检查服务端日志,没有发现有响应超时的现象,网上搜索说nginx的location中增加proxy_ignore_client_abort on;  这个设置,可以去除499,

后来查了一下,这个参数设置是目的是,服务端不管客户端连接是否断开继续执行,加上这个参数后发现真的没有499了,但是问了客户端的超时情况,没有什么变化,从刚开始检查没有发现服务端有响应异常的日志看,proxy_ignore_client_abort on; 这个参数也只能更加准确验证服务端真的没问题,还是客户端在和nginx连接中哪里有问题,再加上客户端反应有超时,怀疑是连接过程中网络有问题,正好有几个其他的服务团队也反映服务有超时,同时他们发现公司内网dns解析服务器好像有问题,一问刚才的客户端同事,他们也用了公司的内网的dns服务,我让他们找一台机器绑定一下hosts试试,立即通过监控发现超时减少了,同时运维同事也承认dns缓存有点问题,至此问题已然明了

proxy_ignore_client_abort on; 这个参数后面又从nginx注释了,如果真的是服务端有某些接口响应有问题,这个参数会引起连接不能释放,最后可能拖垮服务端,建议只在出现问题的时候,作为排查临时使用


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值