1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > qt连接错误ip的sqlserver超时时间_参数设置导致请求超时案例

qt连接错误ip的sqlserver超时时间_参数设置导致请求超时案例

时间:2018-11-20 02:57:19

相关推荐

qt连接错误ip的sqlserver超时时间_参数设置导致请求超时案例

问题现象

晚上版本上线后,发现工号进入首页后页面空白,显示INTERNAL_SERVER_ERROR

过程回顾

通过fiddler抓包,发现某个请求出现500错误检查应用,was,ihs日志,没有发现有效日志发现只有部分工号有问题,开始怀疑存在数据问题,准备导数据回测试环境验证同时,新建一套ihs和was环境进行验证新环境验证,发现原来失败的工号可以正常,怀疑环境配置有问题。同时发现请求超过4s就会返回500错误尝试直接访问原was,发现是正常的对比两个环境配置,was和ihs配置是一样的,但plugins-in参数ServerIOTimeout有差异,旧的是-1,新的为0修改新的为-1,访问问题重现准备修改为0,问题修复

技术分析

关于ServerIOTimeout参数的描述,以及取值为负数的情况,描述如下:

ServerIOTimeout value can be either positive or negative. If positive, when the ServerIOTimeout pops, the plug-in will not mark that server down. If negative, when the ServerIOTimeout pops, it will mark that server down. If your application uses HttpSession object, then there will be session affinity in play, so it would be best to choose a negative ServerIOTimeout value, to ensure that the retry will not be sent back to the same server that just timed-out. Since that server will be marked down, the retry will go to a different appserver in the cluster.

简单来说,关于参数的取值都是需要权衡的。ServerIOTimeout表示ihs和was之间连接的读写超时时间,取值有三种值:

0 表示一直等待was响应,这样可能会造成长时间不响应,连接也不释放正数 表示读写超时时间,超时之后会重试,这样可能会造成业务重复受理负数 和正数一样,不过超时之后会认为当前was为下线状态,然后重试其他服务器,对于无状态的请求同样可能有重复受理的问题。在上面的问题中,ihs后面有4个was,所以刚好看上去就是超过4s会超时

小总结

优化应用日志很重要,特别是那些没什么用的异常日志,需要定期优化现网日志最小化的可重现问题的环境熟悉常见调试工具,如fiddler,telnet,wget,curl,tcpdump等修改参数应该慎重,知道参数的含义,不要想当然。这次就是以为-1和0是没有区别

这个文章也是3年前的,整理分享。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。