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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具