背景:
上周业务方反馈说访问兄弟部门的一个接口超时量突然增加,看监控视图,占比大概5~10%左右。
我登录idc机器curl构造请求测试正常,无延时。对方特意提供了内网vip给我们测试,业务开发修改发布后发现还是有延时。接口方给出延时监控视图,最大延时,如下图:
这个视图只能说明建立连接成功的请求状况,但现在双方都说服不了对方。开发甚至认为是机器环境有问题,要求运维查清楚。
苦逼的取证过程:
我重新用curl构造请求测试了内网vip、外网vip,发现都正常,直接curl 也是ok的。说明网络没问题,那问题出在接口方。能否模拟server那样大并发请求验证下呢?顺手写了个简单的python脚本并发请求接口:
-
import urllib2
-
from multiprocessing import Pool
-
-
def worker(id):
-
while id:
-
try:
-
headers={"Host": 'view.inews.xxoo.com', 'User-agent':'Mozilla/5.0 (Linux i686)'}
-
req=urllib2.Request('',None,headers)
-
reqcode=urllib2.urlopen(req).code
-
#reqcode=urllib2.urlopen('http:///').code
-
return reqcode
-
except:
-
return None
-
-
-
if __name__ == '__main__':
-
pool = Pool(4)
-
print pool.map(worker, range(1,20))
-
pool.close()
-
pool.join()
测试内网vip,第一次跑脚本ok,但第二次就出现connect timeout:
但是测试是ok的!!
联系业务开发和接口方,继续strace 跟踪脚本连接:
这个结果就比较清晰了,像是
syn包直接被丢掉了。
后来,接口方的运维查到原因是lvs后的一台rs没有回包,但lvs oss系统没有及时剔除掉有问题的机器。
阅读(3478) | 评论(0) | 转发(0) |