首页 > 系统服务 > 详细

jmeter测试接口-打开很多TCP的连接数TIME_WAIT状态(Linux环境)导致报错的解决方法

时间:2017-06-21 18:04:08      阅读:1301      评论:0      收藏:0      [点我收藏+]

标签:times   mes   all   80端口   文件中   net   ges   有效   linux环境   

  一 发现问题:

  服务器是Linux系统,用jmeter测试接口,发现打开很多的TCP连接,[root@m3-2 bin]# ulimit -n 65535用这个命令设置了总的连接数;进行压测的时候,连接数可能达到50000以上,很容易报错;查看各个状态的TCP个数:
netstat -an | awk ‘/^tcp/ {++s[$NF]} END {for(a in s) print a,s[a]}‘,发现连接状态TIME_WAIT的状态很多,(统计80端口连接数netstat -nat|grep -i 80|wc -l用这个统计也行)。而不报错的接口,打开的TCP连接数比较少,约在15000-25000这样。

  初步怀疑是tcp的TIME_WAIT状态太多了,导致连接的时间过长,系统的端口资源被长时间的占用,新的请求,又分配不到资源。

  二 解决方式:

  经过3天多的时间,终于找到了有效的解决方案,可以参考该微博:http://blog.oldboyedu.com/tcp-wait/:

在sysctl.conf配置文件中# vim /etc/sysctl.conf,修改成如下的配置:

net.ipv6.conf.all.disable_ipv6 = 1
net.ipv6.conf.default.disable_ipv6 = 1

net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_timestamps = 1

再运行起来,TCP的连接数明显下降了,而且接口的TPC上升了,不容易报错,如下图所示:

技术分享

 

jmeter测试接口-打开很多TCP的连接数TIME_WAIT状态(Linux环境)导致报错的解决方法

标签:times   mes   all   80端口   文件中   net   ges   有效   linux环境   

原文:http://www.cnblogs.com/feng-1314/p/7060853.html

(0)
(0)
   
举报
评论 一句话评论(0
0条  
登录后才能评论!
© 2014 bubuko.com 版权所有 鲁ICP备09046678号-4
打开技术之扣,分享程序人生!
             

鲁公网安备 37021202000002号