文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

java之生产故障定位Arthas问题

2024-04-02 19:55

关注

生产故障定位Arthas

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

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

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

特别说明

 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中体现。

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

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

watch demo.MathGame primeFactors 'target.illegalArgumentCount'

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

获取类的静态字段

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

调用类的静态方法。

参考:arthas官方文档

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯