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

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

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

解决指定参数
tt -t *Test print params[0].mobile=="13989838402"

筛选出 primeFactors 方法的调用信息
tt -s 'method.name=="primeFactors"'

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

重做一次调用
tt -i 1003 -p

除了如上的写法之外,其实后面还可以跟参数,具体常用可跟参数如下:
--replay-times:指定调用次数--replay-interval:指定多次调用间隔(单位ms,默认1000ms)
tt -i 1003 -p --replay-times 3 --replay-interval 2



浙公网安备 33010602011771号