arthas
是一个Java
开源诊断神器。
今天分享一个非常重要的命令watch
,官网定义这个方法的功能如下:让你能方便的观察到指定方法的调用情况。能观察到的范围为:返回值、抛出异常、入参,通过编写 OGNL 表达式进行对应变量的查看。
由于涉及到比较多的命令参数和ognl
表达式的应用,内容比较多,所以分了上下两期,上主要讲官网Demo
内容,下主要讲实践。顺道说一下,官网的文档标题和实际Demo
有几处不太一致的地方,大家如果要学习的话,以Demo
代码展示为主就好。
参数名称 | 参数说明 |
---|---|
class-pattern | 类名表达式匹配 |
method-pattern | 方法名表达式匹配 |
express | 观察表达式 |
condition-express | 条件表达式 |
[b] | 在方法调用之前观察 |
[e] | 在方法异常之后观察 |
[s] | 在方法返回之后观察 |
[f] | 在方法结束之后 (正常返回和异常返回) 观察 |
[E] | 开启正则表达式匹配,默认为通配符匹配 |
[x:] | 指定输出结果的属性遍历深度,默认为 1 |
watch
命令定义了 4 个观察事件点,即-b
方法调用前,-e
方法异常后,-s
方法返回后,-f
方法结束后-b
、-e
、-s
默认关闭,-f
默认打开,当指定观察点被打开后,在相应事件点会对观察表达式进行求值并输出-b
事件点 params
代表方法入参外,其余事件都代表方法出参-b
时,由于观察事件点是在方法调用前,此时返回值或异常均不存在Fhaohaizi@163.com
。