Arthas-tt

作用

方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测,watch 虽然很方便和灵活,但需要提前想清楚观察表达式的拼写,这对排查问题而言要求太高,因为很多时候我们并不清楚问题出自于何方,只能靠蛛丝马迹进行猜测。

tt -t demo.MathGame primeFactors

image-20211102223843115

字段说明:

  • INDEX:时间片段记录编号,每一个编号代表着一次调用,后续 tt 还有很多命令都是基于此编号指定记录操作,非常重要
  • TIMESTAMP:方法执行的本机时间,记录了这个时间片段所发生的本机时间
  • COST(ms):方法执行的耗时
  • IS-RET:方法是否以正常返回的形式结束
  • IS-EXP:方法是否以抛异常的形式结束
  • OBJECT:执行对象的 hashCode(),注意,曾经有人误认为是对象在 JVM 中的内存地址,但很遗憾他不是。但他能帮助你简单的标记当前执行方法的类实体
  • CLASS:执行的类名
  • METHOD:执行的方法名

解决方法重载

tt -t *Test print params.length==1

image-20211102224030666

tt -t *Test print 'params[1] instanceof Integer'

image-20211102224139334

解决指定参数

tt -t *Test print params[0].mobile=="13989838402"

image-20211102224333370

筛选出 primeFactors 方法的调用信息

tt -s 'method.name=="primeFactors"'

image-20211102224425218

查看调用信息

对于具体一个时间片的信息而言,你可以通过 -i 参数后边跟着对应的 INDEX 编号查看到它的详细信息:

tt -i 1003

image-20211102224714460

重做一次调用

tt -i 1003 -p

image-20211102224826525

除了如上的写法之外,其实后面还可以跟参数,具体常用可跟参数如下:

  • --replay-times:指定调用次数
  • --replay-interval:指定多次调用间隔(单位ms,默认1000ms)
tt -i 1003 -p --replay-times 3 --replay-interval 2

image-20211102225217986

End

posted @ 2021-11-02 22:53  BNTang  阅读(202)  评论(0)    收藏  举报