FULLGC频繁排查
# 1 获取dump文件
排查FUllGC频繁,一般都是获取到当时的dump文件,分析内存里都有哪些数据占用较多内存。
有两种办法可以获取dump文件
通过在jvm里添加参数:
+HeapDumpBeforeFullGC
+HeapDumpAfterFullGC
这种方法需要在应用启动前要提前配置好。使用jinfo命令进行设置。(生产环境常用的方法)
无需重启jvm,即时生效,dump文件生成后,清除JVM参数,通常
fullgc
会频繁发生,拿到一次的dump采样后,清除参数,然后慢慢分析dump文件
第一步,通过jps获得java程序的pid(jps,ps等方法)
#jps
5940 Main
3012 Jps
1
2
3
2
3
第二步,调用jinfo命令设置JVM参数
#jinfo -flag +HeapDumpBeforeFullGC 5940
#jinfo -flag +HeapDumpAfterFullGC 5940
#jinfo -flags pid 检查有没有生效
1
2
3
4
2
3
4
下次发生fullgc时就会生成dump文件,dump文件取到后我们就可以清除原来设置的参数:
#jinfo -flag -HeapDumpBeforeFullGC 5940
#jinfo -flag -HeapDumpAfterFullGC 5940
#jinfo -flags pid 检查有没有生效
1
2
3
4
2
3
4
dump文件可以借助MAT、Jprofiler等工具分析。
上次更新: 2022/11/24, 17:59:25