arthas的vmtool

vmtool这个命令最大的作用是可以对内存对象的查询。
我个人总结的一些使用场景:

  1. 项目中读取配置文件,初始化的配置类。我们在排查问题时候,需要确认配置类属性值是否符合预期
  2. 项目中各种缓存用的Map,List等等。在排查问题时候需要确认当前缓存的信息是否符合预期
示例1:

在这里插入图片描述
这个类会在项目初始化的时候,做缓存map的初始化操作。大家平时项目代码中可能也会有这样的一些缓存map(读取数据库,定时刷新等等的map)。
如果我们要查看缓存map的内容来定位问题,就可以使用vmtool来实现。
在这里插入图片描述

示例2:

在这里插入图片描述
在这里插入图片描述

ConfigProperties是一个读取配置文件配置类,如果我们要查看线上配置类读取初始化的属性是否正确,可以借助vmtool.
在这里插入图片描述


vmtool命令基本结构:

vmtool --action getInstances --className {你需要查看的类} --express '{表达式}' -x 3
  • --express:可以查看指定的某个属性字段数据
  • -x 3:可以调整对象输出的层级,对于层级比较多的对象可以加大-x参数值
  • -c:对于一个jvm里有多个相同类对象时候,可以用-c参数指定要查看的对象的classloader的hash值来实现(该类的classloader的hash值可以用sc参数查询)

tips: 表达式里instances[0]这一部分大部分使用情况下也可以保持不变

我们调整下express再执行一次命令,来实现查看map里具体数据:
在这里插入图片描述
在这里插入图片描述

补充

最后补充下-c参数指定classloader的hash值获取命令sc
sc命令:sc -d {全类名}
在这里插入图片描述
vmtool通过-c 指定classloader hash值。
在这里插入图片描述

Arthas(阿尔萨斯)是阿里巴巴开源的Java诊断工具,深受开发者喜爱。 当你遇到以下类似问题而束手无策时,Arthas 可以帮助你解决: 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception? 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了? 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗? 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现! 是否有一个全局视角来查看系统的运行状况? 有什么办法可以监控到JVM的实时运行状态? 怎么快速定位应用的热点,生成火焰图? Arthas支持JDK 6+,支持Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的Tab自动补全功能,进一步方便进行问题的定位和诊断。   Arthas开源的Java诊断工具 更新日志: v3.5.1 Add vmtool command Remove the useless resetClassFileTransformer in Enhancer 对于非chunk response,返回标准的content-length字段 The jvm command may throw exception: java.lang.NullPointerException jad的一个小小的显示问题 bug remove env JAVA_TOOL_OPTIONS 去掉默认配置项 arthas.enhanceLoaders=java.lang.ClassLoader ,避免attach后导致系统负载飙升 Thread -n -1 不能正常工作 bug 当找不到java进程时,提示不清晰,应该提示用户执行jps命令 增加一个 ognl 的在线,可编辑的示例,帮助用户自己调试 ognl表达式 当Object输出时,可能会抛出异常,打印 ERROR DATA!!! exception message: null 把 arthas-demo 改名为 math-game ,避免新用户感到疑惑 arthas spring boot starter启动失败后,没有打印具体出错端口
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值