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 @   BNTang  阅读(184)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具
点击右上角即可分享
微信分享提示