tomcat假死原因
以前遇到tomcat莫名奇妙的假死了,没有任何的响应,然后重启后又可以了,隔段时间又假死了。以前不懂的处理和排除原因,纠结的半死。无从入手,都想砸电脑,小伙伴们有遇到过,我遇到过4次。
其实tomcat假死引起的原因有很多,要具体分析一下和排查一下。
tomcat假死有以下几种可能的原因:
redis的连接池资源没释放掉(tcp没释放掉,tcp状态为close_wait)
数据库连接池资源没释放掉(tcp没释放掉,tcp状态为close_wait)
上传文件资源没关闭掉 (tcp没释放掉,tcp状态为close_wait)
httpclient请求没关闭掉 (tcp没释放掉,tcp状态为close_wait)
线程死锁
线程被阻塞了,没继续往下执行
tomcat的假死的原因有很多,很多是由于tcp没有释放掉。具体怎么排查原因,下面会介绍一下。
案例1
顺便说我遇到的一个坑,我曾经部署专门做定时任务项目,这个是用spring的quartz做的。发现定时任务执行一段时间后,居然没响应了,tomcat没挂掉,cpu和内存也正常。就是定时任务不执行。查看了线程,也没有死锁。后面查了很久,居然quartz的定时任务调度居然开启的是单线程的。由于我其中一个定时任务要执行消息写入数据库,这个量非常大,而且服务器配置比较差,写入比较慢。所以导致这个任务要执行差不多1天,导致其他定时任务不执行,所以还以为tomcat挂掉了。所以有时候要排查线程数是否足够。
案例2
<