-
查看进程ID:
jps例:

-
查看堆内存占用及GC情况,每5秒刷新一次:
jstat -gcutil 17488 5000例:
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kH7M0sD4-1665243214720)(images/image-20221008214750836-1665236875666-3.png)]](https://i-blog.csdnimg.cn/blog_migrate/e9d408524f9be9d2f14e70b66321e4a6.png)
发现问题: 老年代内存使用率一直接近100%,Full GC次数一直增长 -
排除堆内存过小的可能:增大Xmx参数值
查看命令行初始堆大小及最大堆大小:
java -XX:+PrintCommandLineFlags -version例:
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lnmEcilH-1665243214720)(images/image-20221008220712164-1665238034541-5.png)]](https://i-blog.csdnimg.cn/blog_migrate/15bcda166fb859126939620ea2b2cbf4.png)
在/bin/catalina.sh文件下修改初始堆及最大堆大小:
JAVA_OPTS='-Xms4096m -Xmx4096m' 根据阿里规范两个参数大小最好保持一致,减少堆扩张带来的问题
最后使用 jstat -gcutil 查看老年代空间占用,如果还是满的,说明存在内存泄漏
-
查找内存泄漏具体对象:
jmap -histo 17488根据占用空间大小降序输出
例:
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6XIeCRF7-1665243214720)(images/image-20221008223706420-1665239831187-7.png)]](https://i-blog.csdnimg.cn/blog_migrate/ee78f4fd2472e806c4a2695e909ab3e3.png)
也可只查询前10个最大占用的对象:jmap -histo 17488 | head -n 10
回收掉无用对象,再次查看存活对象:
jmap -histo:live 17488 该命令会执行一次GC,之后打印存活对象
例:
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lplMRKI4-1665243214720)(images/image-20221008223953400.png)]](https://i-blog.csdnimg.cn/blog_migrate/1540cd4107f6066d3278bbe91f95e0fa.png)
结果: 发现某个类对象GC前后实例数变化不大,这个应该就是内存泄漏的类了
-
如果代码中很多地方用到了这个类,则需要Dump转存成文件:
jmap -dump:file=app.dump 17488例:
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vFPaZVTh-1665243214721)(images/image-20221008230201948.png)]](https://i-blog.csdnimg.cn/blog_migrate/c2cd38306415cc688e9af22816745cba.png)
也可以通过参数设置,内存溢出时自动生成dump文件:
‐XX:+HeapDumpOnOutOfMemoryError ‐XX:HeapDumpPath=D:jvm.dump注:内存泄漏dump文件也会很大,可能卡死,可以将Xmx限制在2G,重现问题后再dump
-
使用jhat分析dump文件,寻找GC Root
jhat -J-Xmx2G app.dump![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZpFbyMLj-1665243214721)(images/image-20221008232831669.png)]](https://i-blog.csdnimg.cn/blog_migrate/3a77c16bda1a09fd086f0ef9cba622d9.png)
访问网址:http://localhost:7000
最后:链接到嫌疑类的具体某个对象页面,分析这个对象的引用情况是否正常,再通过“Reference chains from Rootset ”获取所有的GC Root ,进而定位到具体代码位置。
内存泄漏排查
于 2022-10-08 23:47:43 首次发布
5629

被折叠的 条评论
为什么被折叠?



