技术主题
在之前的开发的一个项目中,因为程序的一个bug,导致一些引用的对象一直没有回收,从而导致堆内存一直在增大,老年代一直在增大,老年代进行堆积,后来的排查思路是通过dump堆的文件,然后对文件进行分析,判断当前未回收的大对象。然后在程序中定位到代码,从而进行分析,我写这个博客是为了在这里总结一下,分析堆文件。
模块一:生成dump文件
首先在堆内存偏高的实例上进行dump分析,命令为
jps
jmap -dump:format=b,file=heapdump.hprof PID
这里的pid是当前进程id,首先通过jps获取当前
模块二:排查方式一
第一种是直接在Idea打开profiler,然后将文件放到这里
排查方式二
直接在fastthread.io进行分析,只需要导入堆文件,稍等一会就可以出分析结果,可以看到大对象或者没有回收的对象。但是这个网站有一个缺点是,限制了对于大文件的读取,也就是说如果想要分析的是大文件,会报文件太大导致不能分析。