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