Java中OutOfMemoryError(内存溢出)和Tomcat进程假死崩溃

在SSH+jdk6+tomcat6的老项目中,遇到系统响应延迟、偶尔卡死及Tomcat进程崩溃等问题。初步判断为内存溢出,优化代码后问题暂时缓解,但不久后依旧出现OutOfMemoryError。通过分析Tomcat日志和使用top命令监控,发现特定方法可能导致内存泄露。利用jstack命令在CPU高负载时定位到问题线程,从而进一步解决内存溢出问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

接手一个老项目ssh+jdk6+tomcat6,年底申报信息的系统开始频繁使用了,之前没有暴露的问题显现出来了
1、系统页面的响应时间变的很长。
2、偶尔会卡死,但等一会就好了,隔几天会突然挂掉。
3、tomcat有时会有日志显示GC失败和OutOfMemoryError。
根据以上信息初步判断是内存溢出了,查看了tomcat访问的日志,查看了相关代码中有很多for循环里new对象的操作,更改代码之后重启服务,页面响应时间变短了,但是过了几天还是出现了OutOfMemoryError的提示,并且服务又宕机了。
我还是从tomcat日志中寻找原因,初步确定了可能几个方法造成的内存泄露,然后开始用top命令监控

根据pid查询java线程
top -Hp 31947

在这里插入图片描述
在系统响应非常慢而且cpu已经满了的时候,查看哪个线程消耗资源最大用命令
printf “%x\n” 31977
打印出16进制线程id,
./jstack 31977 | grep 7ce9或者./jstack -l 31977或者kill -3 31977
catalina.out出现堆栈信息
在这里插入图片描述
定位到了内存溢出的方法。
想要定位到内存溢出的方法,需要在cpu被占用很高时查找,有的时候找到的线程可能是jvm的GC线程,多打印几次日志就会找到问题线程方法.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值