服务频繁fullgc无法对外提供服务。需要查看分析出是大对象?内存分配不合理还是造成了内存泄漏的问题。
查找步骤
- 查看,确认gc情况
查看jvm运行参数
dump分析
找出问题代码
查看存活对象情况
- 查看该进程下占用CPU最高的线程
查看,确认gc情况
1 | jstat -gc [pid] 2000 |
每2秒打印一次pid的gc情况
查看jvm运行参数
1 | jinfo -flags [pid] |
dump分析
1 | jmap -dump:live,format=b,file=[filename].hporf [pid] |