文章目录
前言
当需要的内存空间大于系统分配的内存空间时,发生OOM;客户线上环境基本每2周挂一次,暂时编写了脚本自启动应用,需要去定位原因
1.生成Dump文件
1.1 让JVM在遇到OOM(OutOfMemoryError)时生成Dump文件
在应用中添加JVM参数:
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/data/log/sdc
1.2 在服务僵死时,jmap导出
执行jmap -dump:format=b,file=文件名 进程对应的pid
如:
jmap -dump:format=b,file=sdc.hprof 124108
file:保存路径及文件名
pid:进程编号(linux通过ps aux查看)
2. 分析dump文件(使用eclipse的mat图形化工具)
mat工具下载
注: 生成环境使用的版本为jdk8,最新的mat不支持,需要用 之前发行的版本
,使用1.11.0版本
2.1 下载windows版本,直接打开(若dump文件很小)
2.2 下载linux版本,上传到服务器后解压(若dump文件很大)
进入解压后的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文件所在的路径下生成报告文件
把报告文件拷贝到本地磁盘
3. 打开分析报告
3.1 使用浏览器浏览
解压缩以.zip结尾的文件,解压后,使用浏览器打开index.html文件内容,查看分析报告
查看内存泄漏排查: 查看对象占据内存空间的比例
查看线程: