dump文件分析工具有哪些_如何解析xml文件

dump文件分析工具有哪些_如何解析xml文件/前言/在讲解Mat工具之前我们先来看下几个关于Dump/文件的问题Dump文件是什么Dump文件是进程的内存镜像。可以把程序的执行状态通过调试器保存到dump文件中我们拿到Dump文件有什么用的?假如JVM因为内存溢出的原因宕机了,而程序的日志里面并没有关于溢出所在对象的信息,此时我们就需要通过分析Dump文件来找到问题原因Dump文件怎么生成?第一种在启动JVM时指定参数 #指定生成Dump文件的异常类型 -XX:+HeapDumpOnOutOf

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

/ 前言 /

在讲解Mat工具之前我们先来看下几个关于Dump/文件的问题

  • Dump文件是什么

    Dump文件是进程的内存镜像。可以把程序的执行状态通过调试器保存到dump文件中

  • 我们拿到Dump文件有什么用的?

    假如JVM因为内存溢出的原因宕机了, 而程序的日志里面并没有关于溢出所在对象的信息, 此时我们就需要通过分析Dump文件来找到问题原因

  • Dump文件怎么生成?

    • 第一种

      在启动JVM时指定参数

        # 指定生成Dump文件的异常类型
        -XX:+HeapDumpOnOutOfMemoryError
        # 指定Dump文件生成的位置
        -XX:HeapDumpPath=/usr/local/jvm/dumps
      
    • 第二种

      如果你在启动JVM时没有指定参数, 那么可以使用第二种方式来生成Dump文件, 使用JVM自带的工具jmap

      jmap -dump:file=/usr/local/jvm/dumps/check.dump PID
      

      PID的获取可以通过ps | top指令来获取

      ps -ef|grep java
      
      top
      

/ 1 / 安装Mat

Mat是Eclipse的一个插件, 也可以独立运行, 所以即使你使用IDEA也可以独立使用Mat
Mat官网下载地址
dump文件分析工具有哪些_如何解析xml文件
根据操作系统选择对应的版本即可
下载下来是一个zip压缩包解压即可
Mac解压后是一个.app, 直接运行会报错
dump文件分析工具有哪些_如何解析xml文件
我们需要修改一下启动方式或者将.app文件移动到应用程序下

/Users/xxx/Downloads/mat.app/Contents/MacOS/MemoryAnalyzer -data ./workspace

启动后的界面
dump文件分析工具有哪些_如何解析xml文件
启动后在导入Dump文件时有可能会报错

An internal error occurred during: "Parsing heap dump from 'xxx.dump'".
Java heap space

这是因为Dump文件的大小超出了Mat默认的读取范围, 我们需要修改Mat的配置文件
找到MemoryAnalyzer.ini文件
Windows/Linux中该文件就在解压缩的目录下
Mac中该文件在mat.app/Contents/Eclipse

-startup
../Eclipse/plugins/org.eclipse.equinox.launcher_1.5.0.v20180512-1130.jar
--launcher.library
../Eclipse/plugins/org.eclipse.equinox.launcher.cocoa.macosx.x86_64_1.1.700.v20180518-1200
-vmargs
-Xmx4g
-Dorg.eclipse.swt.internal.carbon.smallFonts
-XstartOnFirstThread

修改-Xmx的值即可

/ 2 / Mat功能介绍

2 . 1 Overview

Dump文件信息, 使用饼状图的方式来展示内存占用的信息

  • Details是文件信息详情, 包含了文件大小、字节码文件大小、对象文件大小、类加载器数量
  • Actions是常用的操作汇总, 与左上角的菜单功能相同

2 . 2 Histogram

Histogram汇总了使用到的类的对象数量以及堆占用空间
dump文件分析工具有哪些_如何解析xml文件
我们还可以根据实际情况对Histogram展示的数据进行分类
dump文件分析工具有哪些_如何解析xml文件
在结果的第二行<Regex>中我们可以进行模糊查询

2 . 3 Dominator_Tree

Dominator_Tree汇总了堆内存空间中占比最大的对象, 按照空间大小排序, 我们可以通点击左边的箭头符号查看当前对象的引用状况, 最右侧为当前对象所占空间比例
dump文件分析工具有哪些_如何解析xml文件

2 . 4 OQL

OQL是Object Query Language的简写,即对象查询语言, 语法与SQL类似, 点击上方的红色感叹号开始执行
dump文件分析工具有哪些_如何解析xml文件

2 . 5 Thread_Overview

线程视图, 汇总了Dump文件中所有线程的信息, 按照线程所占用的空间进行排序

2 . 6 Leak Suspects

内存泄漏疑点, 这是Mat根据Dump文件的分析结果得到最有可能导致OOM的疑点, 也是我在使用Mat工具时第一个打开的工具
dump文件分析工具有哪些_如何解析xml文件
点击Details查看详细分析信息

2 . 7 Path to GC Roots & Merge Shortest Paths to GC Roots

研究这俩个工具之前我们需要先了解一下GC对不同引用关系之间的区别

2 . 7 . 1 GC对不同引用关系之间的区别
  • 虚引用(PhantomReference)

    虚引用无法决定一个对象的生命周期, 因为持有虚引用的对象和没有引用一样, 随时都会被GC回收, 且虚引用的使用必须搭配引用队列一起使用PhantomReference

  • 弱引用(WeakReference)

    与虚引用相比拥有短暂的生命周期, 长短则取决于GC什么时候回发现它, 需要搭配WeakReference来使用

  • 软引用(SoftReference)

    与弱引用相比, 软引用的生命周期长短取决于堆内存是否充足, 如果堆内存已经满了, 那么GC就会回收软引用对象

  • 强引用(StrongReference)

    我们平常创建对象时都是创建的强引用对象, 不论堆内存是否充足, 只要该对象还存在引用关系GC就不会回收, 这也是OOM异常的触发原因

2 . 7 . 2 Path to GC Roots

当前对象到GC Root的路径, 也就是当前对象的引用关系, 该工具只能展示单个对象的引用关系, 所以只能在Dominator_Tree中使用

2 . 7 . 3 Merge Shortest Paths to GC Roots

一组对象到GC Root的最短路径, 效果与Path to GC Roots相同, 可以在Histogram中使用
dump文件分析工具有哪些_如何解析xml文件
选择一条数据点击右键并选择Path To GC Roots, 选择展示结果排除需引用、弱引用、软引用, 我们只需要看强引用即可
dump文件分析工具有哪些_如何解析xml文件

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/186570.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • git merge用法详解_git merge 冲突

    git merge用法详解_git merge 冲突一、开发分支(dev)上的代码达到上线的标准后,要合并到master分支gitcheckoutdevgitpullgitcheckoutmastergitmergedevgitpush-uoriginmaster二、当master代码改动了,需要更新开发分支(dev)上的代码gitcheckoutmastergitpullgitch…

    2022年10月19日
    0
  • linux ioctl函数详解,ioctl函数详解「建议收藏」

    linux ioctl函数详解,ioctl函数详解「建议收藏」1.介绍Linux网络程序与内核交互的方法是通过ioctl来实现的,ioctl与网络协议栈进行交互,可得到网络接口的信息,网卡设备的映射属性和配置网络接口.并且还能够查看,修改,删除ARP高速缓存的信息,所以,我们有必要了解一下ioctl函数的具体实现.2.相关结构体与相关函数#includeintioctl(intd,intrequest,….);参数:d-文件描述符,这里是对网络套…

    2022年10月18日
    0
  • Oracle cursor_sharing 参数 详解

    Oracle cursor_sharing 参数 详解

    2022年2月22日
    42
  • A标签去掉下划线

    A标签去掉下划线A标签去掉下划线 a:link{text-decoration:none;color:blue} a:active{text-decoration:blink} a:hover{text-decoration:underline;color:red} a:visited{text-decoration:none;color:green}

    2022年6月7日
    30
  • Python创建微信机器人「建议收藏」

    Python创建微信机器人「建议收藏」微信,一个日活10亿的超级app,不仅在国内社交独领风骚,在国外社交也同样占有一席之地,今天我们要将便是如何用Python来生成一个微信机器人,突然想起鲁迅先生曾经说过的一句话:因为是微信机器人系列的第一篇文章,所以猪哥会特别详细的讲解每一地方,尽量使每一位想学习的同学都能顺顺利利的开始,下面就让我们一起来做些有趣的事吧!一、项目介绍1.微信库选择python关于开发微信的库主要有it…

    2022年4月19日
    281
  • recvfrom error 10022

    recvfrom error 10022http://blog.sina.com.cn/s/blog_6ffee9410100pqdt.html折腾了一个下午加大半个晚上,查了300多个网页,20多个技术论坛,终于把这个问题解决了,真不容易。总结下出现这个错误的一般原因和我出错的原因。出现这个错误的一般原因:1.fromlen参数没有初始化2.from参数没有设置正确,也就是结构问题3.参

    2022年7月23日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号