当前位置: 代码网 > 服务器>服务器>Tomcat > Tomcat假死的原因分析及解决方案

Tomcat假死的原因分析及解决方案

2024年05月14日 Tomcat 我要评论
tomcat假死的原因分析及解决在参与搜人项目时,遇到tomcat假死的问题。当时情况:1、ps tomcat正在运行2、用netstat 查看8080连接情况,有大量的close-wait,还有一些

tomcat假死的原因分析及解决

在参与搜人项目时,遇到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个,服务器就会出现上述假死现象。

解决方案1

及时断开socket

解决方案2

修改tomcat配置文件,修改最大连接数(增大)

修改server.xml配置文件,connector节点中增加acceptcount和maxthreads这两个属性的值,并且使acceptcount大于等于maxthreads:

protocol="org.apache.coyote.http11.http11nioprotocol"
<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

总结 

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com