概要笔者所管理的测试一台业务服务器,近期经常被反馈应用卡顿并且出现过多次内存溢出,本篇为对此问题的处理过程的记录。服务器环境采用oracle jdk1.6,虚拟机为HosSpot,WEB容器为Tomcat7。处理过程获取堆内存转储快照在用户
笔者所管理的测试一台业务服务器,近期经常被反馈应用卡顿并且出现过多次内存溢出,本篇为对此问题的处理过程的记录。
服务器环境采用oracle jdk1.6,虚拟机为HosSpot,WEB容器为Tomcat7。
在用户反馈系统卡顿时,登陆服务器通过命令查看内存使用情况
jps #获取java的进程IDjstat -GC 31795 #31795为jps查询到的进程ID
得到内存使用情况如下:
S0C S1C S0U S1U EC EU OC OU PC PU YGC YGCT FGC FGCT GCT 932032.0 932032.0 0.0 0.0 932096.0 932096.0 5592448.0 5592448.0 131072.0 60017.9 20 13.991 69 892.270 906.260
从结果可以得知,堆内存已经达到容量上限,并且在不断的进行FGC,所以应用系统表现的特别卡顿。
通过jmap命令生成堆转储快照:
jmap -dump:fORMat=b,file=heap.hprof 31795
出现以下提示则表示生成成功:
Attaching to process ID 31795, please wait...Debugger attached successfully.Server compiler detected.JVM version is 20.45-b01Dumping heap to heap.hprof ...Heap dump file created
使用MemoryAnalyzer打开堆转储快照,但提示heap space的堆内存溢出的异常:
An internal error occurred during: "Parsing heap dump from 'java_pid4259.hprof'".Java heap space
修改配置MemoryAnalyzer.ini,调整堆内存大小
-Xms1024m-Xmx8192m
在MAT的Leak Suspects中,可以看到很详细的信息,有两个对象占用了大量的内存。
通过查看线程信息发现为一个报表功能,该报表查询的数据量太大,而且sql效率比较低。
--结束END--
本文标题: 记一次JVM内存溢出的处理过程
本文链接: https://lsjlt.com/news/230236.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0