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