首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Arthas heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)

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

原创
作者头像
刘大猫
发布2025-05-23 21:26:00
发布2025-05-23 21:26:00
2400
举报
文章被收录于专栏:JAVA相关JAVA相关

@toc

二、命令列表

2.1 jvm相关命令

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

基本用法: heapdump options <file-path>

参数说明:

参数名称

参数说明

--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 指定输出的路径及文件名

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

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

代码语言:java
复制
[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对应用采样,生成火焰图)

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 二、命令列表
    • 2.1 jvm相关命令
      • 2.1.8 heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)
  • 本人其他相关文章链接
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档