前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >Arthas-tt

Arthas-tt

原创
作者头像
程序员 NEO
发布2023-09-30 19:42:35
发布2023-09-30 19:42:35
1940
举报

作用

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

代码语言:shell
复制
tt -t demo.MathGame primeFactors
image-20211102223843115
image-20211102223843115

字段说明:

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

解决方法重载

代码语言:shell
复制
tt -t *Test print params.length==1
image-20211102224030666
image-20211102224030666
代码语言:shell
复制
tt -t *Test print 'params[1] instanceof Integer'
image-20211102224139334
image-20211102224139334

解决指定参数

代码语言:shell
复制
tt -t *Test print params[0].mobile=="13989838402"
image-20211102224333370
image-20211102224333370

筛选出 primeFactors 方法的调用信息

代码语言:shell
复制
tt -s 'method.name=="primeFactors"'
image-20211102224425218
image-20211102224425218

查看调用信息

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

代码语言:shell
复制
tt -i 1003
image-20211102224714460
image-20211102224714460

重做一次调用

代码语言:shell
复制
tt -i 1003 -p
image-20211102224826525
image-20211102224826525

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

  • --replay-times:指定调用次数
  • --replay-interval:指定多次调用间隔(单位ms,默认1000ms)
代码语言:shell
复制
tt -i 1003 -p --replay-times 3 --replay-interval 2
image-20211102225217986
image-20211102225217986
End
End

我正在参与2023腾讯技术创作特训营第二期有奖征文,瓜分万元奖池和键盘手表

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 作用
  • 解决方法重载
  • 解决指定参数
  • 筛选出 primeFactors 方法的调用信息
  • 查看调用信息
  • 重做一次调用
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档