TA的每日心情  | 开心 2021-12-13 21:45 | 
|---|
 
  签到天数: 15 天 [LV.4]偶尔看看III  
 | 
 
| 
 
 在参与搜人项目时,遇到tomcat假死的问题。  
当时情况:  
1、ps tomcat正在运行  
2、用netstat 查看8080连接情况,有大量的close-wait,还有一些等待连接的状态  
3、查看服务器的使用情况,没有过多的消耗内存和CPU  
4、重新加载界面,没有报错,只是显示加载失败  
5、加载时看到tomcat 日志报错 out of memary  
在网上查看资料,问题得到解决  
  
- 服务器配置:linux+tomcat
 - 现象:Linux服务器没有崩,有浏览器中访问页面,出现无法访问的情况,没有报4xx或5xx错误(假死),并且重启tomcat后,恢复正常。
 - 原因:tomcat默认最大连接数(线程数)200个,默认每一个连接的生命周期2小时(7200秒),tomcat使用http 1.1协议,而http1.1默认是长连接。tomcat接受处理完请求后,socket没有主动关闭,因此如果在2小时内,请求数超过200个,服务器就会出现上述假死现象。
 - [b]解决方案1:及时断开socket[/b]
 - [b]解决方案2:修改tomcat配置文件,修改最大连接数(增大)[/b]
 
  复制代码 
 修改server.xml配置文件,Connector节点中增加acceptCount和maxThreads这两个属性的值,并且使acceptCount大于等于maxThreads:  
    
   
 - protocol="org.apache.coyote.http11.Http11NioProtocol"
 
  复制代码 
   
    
    
    
- [/code] 
 -  <Connector port="8080" protocol="HTTP/1.1"
 -  
 -  [code]
 
  复制代码 
             connectionTimeout="20000"   
- [/code] 
 -  [code]           redirectPort="8443" acceptCount="500" maxThreads="400" />
 
  复制代码 
 解决方案3:修改linux的TCP超时时间(socket生命周期)限制  
   
    
     
      
      
      1 
       
      
      2 
       
      
      3 
       
      
      4 
       
      
      5 
       
      
      6 
       
      
      7 
       
      
      8 
       
      
      9 
       
      
      10 
       
      
      11 
       
      
      12 
        
      
       
       
       
                    
       
      - # Decrease the time default value for tcp_fin_timeout connection
 
  复制代码         
       
      - net.ipv4.tcp_fin_timeout = 30
 
  复制代码         
       
      - # Decrease the time default value for tcp_keepalive_time connection
 
  复制代码         
       
      - net.ipv4.tcp_keepalive_time = 1800
 
  复制代码         
       
              
       
      - net.ipv4.tcp_keepalive_probes=2
 
  复制代码         
       
              
       
      - net.ipv4.tcp_keepalive_intvl=2
 
  复制代码         
       
         
        
       
                          
       
            - # /etc/rc.d/init.d/network restart
 
  复制代码         
        
     
    
   
 
  
  |   
 
 
 
 |