微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

请你谈谈频繁full gc怎么排查?

通常的处理,我们还是要在FULLGC时取到当时的dump文件,来分析内存里都有哪些数据占居着内存。这里有两种办法来获取dump文件

1.通过在jvm里添加参数配置:+HeapDumpBeforeFullGC,+HeapDumpAfterFullGC 这种方法需要在应用启动前要提前配置好,如果不需要的话,还需要修改jvm参数重启应用。

2.使用jinfo命令进行设置。(生产环境常用的方法
无需重启jvm,即时生效,dump文件生成后,清除JVM参数,通常fullgc 会频繁发生,不需要一直导出dump,所以拿到一次的dump采样后, 即可清除,然后慢慢分析dump文件

第一步,通过jps获得java程序的pid(jps,ps等方法

#jps
5940 Main
3012 Jps

第二步,调用jinfo命令设置JVM参数

#jinfo -flag +HeapDumpBeforeFullGC 5940
#jinfo -flag +HeapDumpAfterFullGC 5940
使用 #jinfo -flags pid 检查有没有生效

下次发生fullgc时就会生成dump文件,dump文件取到后我们就可以清除原来设置的参数:

#jinfo -flag -HeapDumpBeforeFullGC 5940
#jinfo -flag -HeapDumpAfterFullGC 5940
使用 #jinfo -flags pid 检查有没有生效

dump文件的分析,我们就可以借助MAT等工具分析

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐