栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

jvm oom内存溢出,导出dump,使用mat进行问题分析

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

jvm oom内存溢出,导出dump,使用mat进行问题分析

文章目录
  • 前言
    • 1.生成Dump文件
      • 1.1 让JVM在遇到OOM(OutOfMemoryError)时生成Dump文件
      • 1.2 在服务僵死时,jmap导出
    • 2. 分析dump文件(使用eclipse的mat图形化工具)
      • 2.1 下载windows版本,直接打开(若dump文件很小)
      • 2.2 下载linux版本,上传到服务器后解压(若dump文件很大)
    • 3. 打开分析报告
      • 3.1 使用浏览器浏览
      • 3.2 使用eclipse的mat工具
    • 4. 问题解决

前言

  当需要的内存空间大于系统分配的内存空间时,发生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文件内容,查看分析报告

3.2 使用eclipse的mat工具

  


4. 问题解决
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/827913.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号