当线上应用出现内存泄漏、假死等情况时,需要分析内存,快速定位原因,由于jmap生成的内存快照文件较大,动不动几个G,网络传输很慢,此时需要依赖第三方工具做分析后导出,此处选择MemoryAnalyzer,易用,功能齐全
下载地址:https://eclipse.dev/mat/downloads.php
根据jdk版本下载对应兼容版
版本:
jdk11对应版本 MemoryAnalyzer-1.9.2.20200115-linux.gtk.x86_64.zip
jdk11对应版本 MemoryAnalyzer-1.15.0.20231206-linux.gtk.x86_64.zip
其他版本需自行测试
使用:
下载后解压 unzip MemoryAnalyzer-1.9.2.20200115-linux.gtk.x86_64.zip
配置:
自定义配置jdk,
在MemoryAnalyzer.ini文件内顶部添加如下脚本(非必须,需要自定义jdk版本时才配置)
-vm
/usr/local/src/jdk-11.0.17/bin
在ParseHeapDump.sh内配置执行内存,避免生成分析内存文件时内存溢出
-vmargs -Xmx4g -XX:-UseGCOverheadLimit
执行:
1、jmap -dump:format=b,file=java_pid.hprof pid
导出内存信息文件
2、生成分析文件
./ParseHeapDump.sh /opt/java/java_pid.hprof
org.eclipse.mat.api:suspects
执行完成后生成
java_pid_Leak_Suspects.zip
文件在java_pid.hprof所在目录,如上所示:/opt/java/
下载java_pid_Leak_Suspects.zip解压通过浏览器打开index,即可看到内存情况