您现在的位置是:网站首页 > 代码编程 > JAVA开发JAVA开发

【原】利用mat分析hprof文件排查线上oom问题

不忘初心 不忘初心 2022-06-17 围观() 评论() 点赞() JAVA开发

简介:之前给大家演示jvmsualvm分析oom的时候,大家看到我准备了两份hprof文件,其中有一份eureka.hprof文件就是我手动从服务器上导出来的这个东西非常吃内存,基本上要是hprof文件的两倍内存才能打的开打开之后生成了许多的文件继续点进去可以看到stacktree继而可以定位到代码

之前给大家演示jvmsualvm分析oom的时候,我准备了两份hprof文件,其中有一份名为eureka.hprof的文件,是我使用jmap -dump命令手动从服务器上导出来的,当时服务器已经卡死了,所以我没办法利用arthas连接到jvm进程,而且我也无法使用jstack命令来精确定位代码,能定位到的也是GC线程。

没办法,我只好将当时的jvm堆内存导出来一份hprof文件,以期对这份文件能分析出结果,最后也是不出我所料,确实从这份文件中找到了导致oom的原因。

不幸的是,虽然将hprof文件导出来了,但是却无法通过jvisualvm工具来分析它。

mat分析oom_JAVA开发_积微成著

如上图,jvisualvm工具装入hprof文件之后,根本看不到导致oom异常的线程是哪一个。

遂,只能祭出mat(memory analyzer tools)来搞定它,这东西跟eclipse长得一模一样,idea用习惯了,这东西看起来还特么颇有一种古老沧桑的感觉。

mat分析oom_JAVA开发_积微成著

不得不说,jvm堆内存的dump文件是真的大,线上服务器基本上都是配置的以G为单位的内存,大的一批,导入也要很久,而且使用这个mat更加严苛,运行mat工具的机器内存要两倍于hprof文件的大小,否则会打开出错。

mat分析oom_JAVA开发_积微成著

如上图,我当时用笔记本电脑直接没能打开它,这是我用家里的台式机打开的这个hprof文件。

mat分析oom_JAVA开发_积微成著

hprof文件加载完毕之后,大家注意上图中的红色框,我特意将入口打上标记,

mat分析oom_JAVA开发_积微成著

打开之后生成了许多的文件

mat分析oom_JAVA开发_积微成著

这个zip里面就是html

mat分析oom_JAVA开发_积微成著

继续点进去可以看到stacktree

mat分析oom_JAVA开发_积微成著

继而可以定位到代码

mat分析oom_JAVA开发_积微成著

往下拖

mat分析oom_JAVA开发_积微成著

oom

加群方式:点击加入群聊

很赞哦! ()

文章评论

  • 请先说点什么
    人参与,条评论

请使用电脑浏览器访问本页面,使用手机浏览器访问本页面会导致下载文件异常!!!

雨落无影

关注上方公众号,回复关键字【下载】获取下载码

用完即删,每次下载需重新获取下载码

若出现下载不了的情况,请及时联系站长进行解决

站点信息

  • 网站程序:spring + freemarker
  • 主题模板:《今夕何夕》
  • 文章统计:篇文章
  • 标签管理标签云
  • 微信公众号:扫描二维码,关注我们