Arthas heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)

在这里插入图片描述

二、命令列表

2.1 jvm相关命令

### 2.1.8 heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)

基本用法
heapdump [options]

参数说明:

参数名称参数说明
–live只包含活动对象(Live Objects),这通常意味着排除已经被垃圾回收器标记为不可达的对象。
–format指定输出文件的格式,默认为 hprof,但也可以选择 bintxt 格式。
-s–skip-finalizer跳过那些在 finalizer 队列中的对象。
–compress压缩输出文件。
–exclude-class排除特定类的对象,可以多次使用以排除多个类。
–include-class只包含特定类的对象,可以多次使用以包含多个类。
–exclude-package排除特定包名下的所有类的对象。
–include-package只包含特定包名下的所有类的对象。
–exclude-instance排除特定实例,可以通过 o 命令获取实例的 id
–include-instance只包含特定实例,可以通过 o 命令获取实例的 id
举例1:假设你想生成一个只包含活动对象的堆转储文件,并将其保存为 /tmp/heapdump.hprof

基础语法
heapdump --live 指定输出的路径及文件名

heapdump --live /tmp/heapdump.hprof
举例2:如果你想要进一步定制堆转储文件的内容,比如只包含特定类的对象,并且以二进制格式存储

基础语法
heapdump --live --include-class=指定类的全路径 --format=指定输出文件的格式

[arthas@24056]$ heapdump --live --include-class=com.hero.lte.ems.sysmanager.cache.AmNeRefCache --format=bin /temporary/tmp1/AmNeRefCache.bin
Dumping heap to --include-class=com.hero.lte.ems.sysmanager.cache.AmNeRefCache ...
Heap dump file created
[arthas@24056]$ 
注意事项
  • 使用 heapdump 命令会消耗一定的系统资源,特别是在大型应用程序中,因此在生产环境中使用时要格外小心。
  • 生成的堆转储文件可能会非常大,特别是当包含了很多对象的时候,因此确保有足够的磁盘空间。
  • 如果你不确定如何使用某个选项,可以使用 help heapdump 命令查看详细的帮助信息。

本人其他相关文章链接

1.Arthas 全攻略:让调试变得简单
2.Arthas dashboard(当前系统的实时数据面板)
3.Arthas thread(查看当前JVM的线程堆栈信息)
4.Arthas jvm(查看当前JVM的信息)
5.Arthas sysprop(查看和修改JVM的系统属性)
6.Arthas sysenv(查看JVM的环境变量)
7.Arthas vmoption(查看和修改 JVM里诊断相关的option)
8.Arthas getstatic(查看类的静态属性 )
9.Arthas heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)
10.Arthas logger(查看 logger 信息,更新 logger level)
11.Arthas mbean(查看 Mbean 的信息)
12.Arthas memory(查看 JVM 内存信息)
13.Arthas ognl(执行ognl表达式)
14.Arthas perfcounter(查看当前 JVM 的 Perf Counter 信息)
15.Arthas vmtool(从 jvm 里查询对象,执行 forceGc)
16.Arthas jad(字节码文件反编译成源代码 )
17.Arthas mc(Memory Compiler/内存编译器 )
18.Arthas redefine(加载外部的.class文件,redefine到JVM里 )
19.Arthas classloader (查看 classloader 的继承树,urls,类加载信息)
20.Arthas sc(查看JVM已加载的类信息 )
21.Arthas sm(查看已加载类的方法信息 )
22.Arthas monitor(方法执行监控)
23.Arthas stack (输出当前方法被调用的调用路径)
24.Arthas trace (方法内部调用路径,并输出方法路径上的每个节点上耗时)
25.Arthas tt(方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测)
26.Arthas watch (方法执行数据观测)
27.Arthas profiler(使用async-profiler对应用采样,生成火焰图)

要使用Arthas来排查Java项目的内存泄漏问题,你可以按照以下步骤进行操作: 1. 下载和启动Arthas:你可以在Arthas的官方网站(https://arthas.aliyun.com/)上下载最新版本的Arthas,并按照前面提到的步骤启动Arthas。 2. 选择目标进程:输入`select <pid>`命令,其中`<pid>`是你想诊断的Java进程的进程ID。 3. 开启HeapDump:输入`heapdump`命令Arthas将会生成一个Heap Dump文件,用于分析内存使用情况。 4. 分析Heap Dump文件:将Heap Dump文件下载到本地,并使用Java内存分析工具,如Eclipse Memory Analyzer(MAT)或VisualVM等,打开该文件进行分析。这些工具可以帮助你定位内存泄漏的原因和具体的对象引用关系。 5. 使用Arthas命令:在Arthas中,你可以使用`jmap`命令查看Java堆内存的使用情况,使用`jclassloader`命令查看类加载器信息,使用`dashboard`命令查看实时的性能指标等等。这些命令可以帮助你进一步分析内存泄漏问题。 6. 根据分析结果进行修复:根据内存分析工具和Arthas的结果,定位到可能引起内存泄漏的代码或对象,然后进行相应的修复,如释放资源、修正错误的引用等。 请注意,内存泄漏问题的排查并不是一项简单的任务,需要结合工具和分析技巧进行深入分析。同时,也建议在项目开发过程中注意内存使用和资源释放,以避免潜在的内存泄漏问题的产生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

刘大猫.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值