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

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

 

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

 

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

 

1、安装

 

  • 获取安装包

 

通过以下地址,获取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
[root@nccztsjb-node-27 data]# 

 

  • 解压安装包

 

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
[root@nccztsjb-node-27 data]#

 

  • 设置jdk

 

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

 

2、 配置

 

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

 

 

 

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

-vmargs -Xmx30g -XX:-UseGCOverheadLimit

 

 

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

 

3、分析dump文件及生成报告

 

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

 

命令如下:

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

 

示例:

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

 

执行过程,如下:

 

[root@nccztsjb-node-27 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
[.

 

执行完成后,会生成一个报告的文件

 

 

将这个文件,解压到本地电脑,通过浏览器就可以进行查看,比如:

 

 

 

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

posted @ 2022-06-13 14:02  Zhai_David  阅读(44)  评论(0编辑  收藏  举报