码迷,mamicode.com
首页 > 其他好文 > 详细

解决CLOSE_WAIT 问题

时间:2015-06-09 08:29:41      阅读:190      评论:0      收藏:0      [点我收藏+]

标签:

转自:http://blog.163.com/kel_scott66/blog/static/11505396320097245547700/
 
解决CLOSE_WAIT 问题关键字: linux tomcat close_wait

最近web服务器在大流量情况下经常出现假死现象,后台log报 too many open files 的错误,加大linux系统的文件打开数是可以解决部分问题,但是时间长了同样出问题,通过查询网络连接发现是tcp连接不关闭造成的。如下:
  netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}‘
  
  LAST_ACK 1
  SYN_RECV 15

  ESTABLISHED 471
  FIN_WAIT1 3
  FIN_WAIT2 52
  SYN_SENT 1
  TIME_WAIT 725

 

 

 

要解决这个问题的可以修改系统的参数,系统默认超时时间的是7200秒,也就是2小时。

tcp_keepalive_time = 7200 seconds (2 hours)
tcp_keepalive_probes = 9
tcp_keepalive_intvl = 75 seconds

 

意思是如果某个TCP连接在idle 2个小时后,内核才发起probe.如果probe 9次(每次75秒)不成功,内核才彻底放弃,认为该连接已失效

 

 

sysctl -w net.ipv4.tcp_keepalive_time=30
sysctl -w net.ipv4.tcp_keepalive_probes=2
sysctl -w net.ipv4.tcp_keepalive_intvl=2

解决CLOSE_WAIT 问题

标签:

原文地址:http://www.cnblogs.com/georgewangii/p/4562452.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!