Tomcat 假死

服务器配置:linux+tomcat

现象:Linux服务器没有崩,有浏览器中访问页面,出现无法访问的情况,没有报4xx或5xx错误(假死),并且重启tomcat后,恢复正常。
原因:tomcat默认最大连接数(线程数)200个,默认每一个连接的生命周期2小时(7200秒),tomcat使用http 1.1协议,而http1.1默认是长连接。tomcat接受处理完请求后,socket没有主动关闭,因此如果在2小时内,请求数超过200个,服务器就会出现上述假死现象。
解决方案1:及时断开socket
解决方案2:修改tomcat配置文件,修改最大连接数(增大)
修改server.xml配置文件,Connector节点中增加acceptCount和maxThreads这两个属性的值,并且使acceptCount大于等于maxThreads:

<Connector port="8080" protocol="HTTP/1.1"
            connectionTimeout="20000"  
           redirectPort="8443" acceptCount="500" maxThreads="400" />

解决方案3:修改linux的TCP超时时间(socket生命周期)限制
vi /etc/sysctl.conf

# 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/sysctl.conf,要重启network 才会生效
[root@temp /]# /etc/rc.d/init.d/network restart

转载自:http://blog.51cto.com/120806872/1651370

### Tomcat假死状态的原因 Tomcat假死状态的主要原因是其默认的最大连接数(线程数)为200个,而每个连接的生命周期默认为2小时(7200秒)。由于Tomcat使用HTTP 1.1协议,默认情况下支持长连接,在处理完请求后不会主动关闭Socket连接。当请求数量超过200个且未及时释放时,服务器会进入所谓的“假死”状态[^3]。 此外,网络问题也可能导致服务假死现象的发生。例如,程序中的响应处理异常或在高吞吐量系统中执行耗时的同步操作可能导致TPS能力下降,从而引发假死状况[^4]。 ### 解决方案 #### 配置调整 通过修改`server.xml`配置文件来优化Tomcat性能参数是一个有效的解决方法。具体来说,可以在`<Connector>`节点中增加两个重要属性:`acceptCount`和`maxThreads`。建议设置如下: ```xml <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" acceptCount="500" maxThreads="400" /> ``` 其中: - `acceptCount`: 表示等待队列长度,即当所有线程都被占用时允许排队的最大请求数; - `maxThreads`: 定义了Tomcat可以创建的最大工作线程数量; 为了防止因线程不足而导致的服务不可用情况发生,应确保`acceptCount`不小于`maxThreads`。 另外,可以通过指定`protocol="org.apache.coyote.http11.Http11NioProtocol"`强制让Tomcat在每次请求结束后立即断开与客户端之间的连接,减少不必要的资源消耗。 #### 资源监控与管理 除了调整配置外,还需要关注后台运行的应用是否存在潜在隐患。比如Redis线程池资源被长时间占用却未能正常回收的情况可能会间接影响到整个系统的稳定性。此时应当仔细审查近期代码变更记录,确认是否有不当的操作行为存在,并采取相应措施加以改进[^5]。 ### 总结 综上所述,针对Tomcat假死问题可以从以下几个方面入手解决问题:一是适当提高并发处理能力和延长超时时限;二是加强对于外部依赖组件如数据库、缓存等使用的监管力度,避免因为第三方因素牵连至整体架构层面出现问题。 ```python # 示例Python脚本用于模拟压力测试场景下观察Tomcat表现 import requests def stress_test(url, num_requests=1000): responses = [] for _ in range(num_requests): try: response = requests.get(url) responses.append(response.status_code) except Exception as e: print(f"Request failed with error {e}") return responses if __name__ == "__main__": url_to_test = "http://localhost:8080/test_endpoint" results = stress_test(url_to_test) success_rate = (results.count(200)/len(results)) * 100 print(f'Success rate of the test was {success_rate}%') ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

科学的N次方

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值