当需要的内存空间大于系统分配的内存空间时,发生OOM;客户线上环境基本每2周挂一次,暂时编写了脚本自启动应用,需要去定位原因
在应用中添加JVM参数:
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/data/log/sdc
执行jmap -dump:format=b,file=文件名 进程对应的pid
如:
jmap -dump:format=b,file=sdc.hprof 124108

file:保存路径及文件名
pid:进程编号(linux通过ps aux查看)
mat工具下载

注: 生成环境使用的版本为jdk8,最新的mat不支持,需要用 之前发行的版本,使用1.11.0版本

进入解压后的mat目录,查看所有文件:

编辑MemoryAnalyzer.ini,调大最大使用内存

配置完成后,在服务中分析dump文件./ParseHeapDump.sh dump文件路径 org.eclipse.mat.api:suspects org.eclipse.mat.api:overview org.eclipse.mat.api:top_components
./ParseHeapDump.sh /data/log/sdc/sdc.hprof org.eclipse.mat.api:suspects org.eclipse.mat.api:overview org.eclipse.mat.api:top_components
在dump文件所在的路径下生成报告文件

把报告文件拷贝到本地磁盘

解压缩以.zip结尾的文件,解压后,使用浏览器打开index.html文件内容,查看分析报告
查看内存泄漏排查: 查看对象占据内存空间的比例

查看线程:
