linux 安装MAT(MemoryAnalyzerTool),并且分析java dump的方法

当我们的java进程出现异常的时候,我们第一件想做的事情是什么呢?应该就是要分析java的内存了。假如说,我们已经有了一个java内存的dump文件,有哪些的方法,可以对这个导出的dump文件进行分析呢?

比如,jhat,mat··· ····

但是,其中最能够查明问题的,恐怕就是MAT这个工具了,那么在接下来的部分中,我们就来看看如何在linux环境中,安装、配置mat,并且用这个工具来分析dump文件······

 

安装

  • 获取安装包

通过以下地址,获取MAT最新的安装包

Eclipse Memory Analyzer Open Source Project | The Eclipse Foundation

  • 将安装包上传到服务器上
[root@nccztsjb-node-27 data]# pwd
/data
[root@nccztsjb-node-27 data]# ls -l MemoryAnalyzer-1.12.0.20210602-linux.gtk.x86_64.zip 
-rw-r--r-- 1 root root 82304050 Jun 10 16:10 MemoryAnalyzer-1.12.0.20210602-linux.gtk.x86_64.zip
  • 解压安装包
unzip MemoryAnalyzer-1.12.0.20210602-linux.gtk.x86_64.zip

# 生成MAT目录
[root@nccztsjb-node-27 data]# ls -l | grep mat
drwxr-xr-x 6 root root         179 Jun 20  2021 mat
  • 设置jdk

MAT的运行需要jdk,这里需要的jdk11以上,安装jdk的过程不赘述。

 

 

配置

在配置的部分,我们主要配置的是ParseHeapDump.sh脚本中的内存参数

 在脚本的最后一行的最后面,加上如下的参数

-vmargs -Xmx30g -XX:-UseGCOverheadLimit

具体的内存的大小,要根据dump的大小来修改,设置的太小会出现OOM的情况。

 

分析dump文件及生成报告

接下来,我们就是要通过ParseHeapDump.sh来分析dump文件

命令如下:

ParseHeapDump.sh <path/to/dump.hprof> [report]*

示例:

./mat/ParseHeapDump.sh ./gl.hprof org.eclipse.mat.api:suspects

执行过程,如下:

[root@ncc data]# ./mat/ParseHeapDump.sh  ./gl.hprof   org.eclipse.mat.api:suspects
WARNING: A terminally deprecated method in java.lang.System has been called
WARNING: System::setSecurityManager has been called by org.eclipse.osgi.internal.framework.SystemBundleActivator (file:/data/mat/plugins/org.eclipse.osgi_3.16.300.v20210525-1715.jar)
WARNING: Please consider reporting this to the maintainers of org.eclipse.osgi.internal.framework.SystemBundleActivator
WARNING: System::setSecurityManager will be removed in a future release
Task: Parsing gl.hprof
[Task: Parsing /data/./gl.hprof
[
Subtask: Scanning /data/./gl.hprof
[
[INFO] Detected compressed references, because with uncompressed 64-bit references the array at 0x7216eff10 would overlap the array at 0x7216ef5e0
[.

执行完成后,会生成一个报告的文件,将这个文件,解压到本地电脑,通过浏览器就可以进行查看,比如:

就可以看到内存泄露的点,然后再依此进行问题的排查即可。

  • 11
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值