请你谈谈频繁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等工具分析

上一篇:JVM 频繁 FULL GC 快速排查整理


下一篇:JVM常用基础参数-XX:+PrintGCDetails与GC参数详解