java之生产故障定位Arthas问题

 更新时间:2022年06月07日 15:17:27   作者:enjoy嚣士  
这篇文章主要介绍了java之生产故障定位Arthas问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

生产故障定位Arthas

Arthas(阿尔萨斯)能为你做什么?

Arthas 是Alibaba开源的Java诊断工具,深受开发者喜爱。当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:

  • 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
  • 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
  • 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
  • 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
  • 是否有一个全局视角来查看系统的运行状况?
  • 有什么办法可以监控到JVM的实时运行状态?
  • 怎么快速定位应用的热点,生成火焰图?

Arthas支持JDK 6+,支持Linux/Mac/Winodws,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。

熟悉C++的同学,应该了解GDB调试工具。Arthas就是java版的GDB工具。

如果想了解学习,可以按照 这个文档来 学习实践

当然,官网 是最好的。

java诊断工具Arthas(watch命令)方法观察神器

能方便的观察到指定方法的调用情况。能观察到的范围为:返回值、抛出异常、入参。 

watch

1、得到要观察类的类属性以及值,调用类方法

2、得到类对象的属性以及值

3、得到方法调用前后的入参、出参值

4、根据调用时长,入参匹配条件,异常情况过滤方法调用情况

参数说明

watch 的参数比较多,主要是因为它能在 4 个不同的场景观察对象。

参数名称参数说明
class-pattern类名表达式匹配
method-pattern方法名表达式匹配
express观察表达式,默认值:{params, target, returnObj}
condition-express条件表达式
[b]在方法调用之前观察
[e]在方法异常之后观察
[s]在方法返回之后观察
[f]在方法结束之后(正常返回和异常返回)观察
[E]开启正则表达式匹配,默认为通配符匹配
[x:]指定输出结果的属性遍历深度,默认为 1

特别说明

  • watch 命令定义了4个观察事件点,即 -b 方法调用前,-e 方法异常后,-s 方法返回后,-f 方法结束后
  • 4个观察事件点 -b、-e、-s 默认关闭,-f 默认打开,当指定观察点被打开后,在相应事件点会对观察表达式进行求值并输出
  • 这里要注意方法入参和方法出参的区别,有可能在中间被修改导致前后不一致,除了 -b 事件点 params 代表方法入参外,其余事件都代表方法出参
  • 当使用 -b 时,由于观察事件点是在方法调用前,此时返回值或异常均不存在
  • 在watch命令的结果里,会打印出location信息。location有三种可能值:AtEnter,AtExit,AtExceptionExit。对应函数入口,函数正常return,函数抛出异常。

 1、观察方法入参

watch demo.MathGame primeFactors "{params,returnObj}" -x 2 -b

执行结果如下图所示 

 result中的Object数组为入参,类型为Integer值分别为-198028,-134246,-2551等。

-b表示观察点为方法调用前。此时方法刚封装好形参,还没有进入方法执行体。

2、同时观察方法调用前和方法返回后

watch demo.MathGame primeFactors "{params,target,returnObj}" -x 2 -b -s -n 2

以上命令可以将调用方法前(-b参数)"{params,target,returnObj}"即入参,this对象和返回参数返回。

可以将调用方法返回后(-s参数)的"{params,target,returnObj}"即入参,this对象和返回参数返回。

如果参数形式为"{params,returnObj}"只返回入参和回参。

以上所有结果均在result中体现。

  • 参数里-n 2,表示只执行两次
  • 这里输出结果中,第一次输出的是方法调用前的观察表达式的结果,第二次输出的是方法返回后的表达式的结果
  • 结果的输出顺序和事件发生的先后顺序一致,和命令中 -s -b 的顺序无关

3、 调整-x的值,观察具体的方法参数值

watch demo.MathGame primeFactors "{params,target,returnObj}" -x 3 -b -s -n 2

-x表示遍历深度,可以调整来打印具体的参数和结果内容,默认值是1。

可以看到MathGame类的实例中的属性和值。

4、入参条件表达式

watch demo.MathGame primeFactors "{params[0],target}" "params[0]<0 -b

过滤出来方法调用前匹配条件为参数>0的入参和this对象,只有满足条件的调用才会返回。

5、按照耗时进行过滤

watch demo.MathGame primeFactors '{params, returnObj}' '#cost>2' -x 2

过滤出来时长调用大于2ms的。

6、观察异常信息

watch demo.MathGame primeFactors "{params[0],throwExp}" -e -x 2

  • -e 表示抛出异常时才触发
  • express中,表示异常信息的变量是throwExp

7、访问当前对象中的某个属性

watch demo.MathGame primeFactors 'target.illegalArgumentCount'

8、获取类的静态字段、调用类的静态方法

获取类的静态字段

 watch demo.MathGame * '{params,@demo.MathGame@random.nextInt(100)}' -v -n 1 -x 2

调用类的静态方法。

参考:arthas官方文档

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 使用jsoup解析html的table中的文本信息实例

    使用jsoup解析html的table中的文本信息实例

    今天小编就为大家分享一篇使用jsoup解析html的table中的文本信息实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05
  • 如何使用Spring AOP预处理Controller的参数

    如何使用Spring AOP预处理Controller的参数

    这篇文章主要介绍了如何使用Spring AOP预处理Controller的参数操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • SpringBoot中的响应式web应用详解

    SpringBoot中的响应式web应用详解

    这篇文章主要介绍了SpringBoot中的响应式web应用详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-11-11
  • Mybatis 插件原理解析

    Mybatis 插件原理解析

    mybatis是一款优秀的ORM开源框架,这个框架具有极强的灵活性,本文再次给大家介绍Mybatis 插件原理,感兴趣的朋友一起看看吧
    2021-10-10
  • Java 并发编程中如何创建线程

    Java 并发编程中如何创建线程

    这篇文章主要介绍了Java 并发编程中如何创建线程,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下
    2021-03-03
  • Java超详细分析泛型与通配符

    Java超详细分析泛型与通配符

    本篇文章带大家认识Java语法泛型与通配符,泛型和通配符是一个非常抽象的概念,简单来说,两者都可以将类型作为“参数”进行传递,不过泛型是在你知道传入什么类型的时候使用的,而通配符是你不确定传入什么类型的时候使用,本文将介绍泛型与通配符的使用及两者间的区别
    2022-03-03
  • SpringBoot实现api加密的示例代码

    SpringBoot实现api加密的示例代码

    在项目中,为了保证数据的安全,我们常常会对传递的数据进行加密。本文主要介绍了SpringBoot实现api加密的示例代码,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • 详解SpringBoot依赖注入和使用配置文件

    详解SpringBoot依赖注入和使用配置文件

    这篇文章主要介绍了SpringBoot依赖注入和使用配置文件的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-01-01
  • Springboot jdbctemplate整合实现步骤解析

    Springboot jdbctemplate整合实现步骤解析

    这篇文章主要介绍了Springboot jdbctemplate整合实现步骤解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • 详解JVM中的本机内存跟踪

    详解JVM中的本机内存跟踪

    在本文里小编给大家整理了一篇关于JVM中的本机内存跟踪的相关知识点内容,有兴趣的朋友们参考学习下。
    2019-07-07

最新评论