🪂Arthas监控
Arthas
简介:
Arthas 是一款线上监控诊断产品,通过全局视角实时查看应用 load、内存、gc、线程的状态信息。
并能在不修改应用代码的情况下,对业务问题进行诊断,包括查看方法调用的出入参、异常,监测方法执行耗时,类加载信息等,大大提升线上问题排查效率。
官方文档地址:https://arthas.aliyun.com/doc/
下载地址:https://arthas.aliyun.com/download/latest_version?mirror=aliyun
IDEA插件:arthas idea
如何使用:(java -jar arthas-boot.jar),选择你的应用程序。
官方手册已经很详细了,可能绝大多数时候,我们不需要使用到那么多参数的场景,比如我们可能就用一个命令的几个参数,但是要将这几个命令单独拎出来演示也是比较繁琐的。
本文旨在使用简短的语言,比如一个命令,说清楚每个参数含义,拿来即用,配合IDEA-Arthas插件演示,更快的提升使用效率;
dashboard:当前系统的实时数据面板
1 | dashboard |
- ID: Java 级别的线程 ID,注意这个 ID 不能跟 jstack 中的 nativeID 一一对应。
- NAME: 线程名
- GROUP: 线程组名
- PRIORITY: 线程优先级, 1~10 之间的数字,越大表示优先级越高
- STATE: 线程的状态
- CPU%: 线程的 cpu 使用率。比如采样间隔 1000ms,某个线程的增量 cpu 时间为 100ms,则 cpu 使用率=100/1000=10%
- DELTA_TIME: 上次采样之后线程运行增量 CPU 时间,数据格式为
秒
- TIME: 线程运行总 CPU 时间,数据格式为
分:秒
- INTERRUPTED: 线程当前的中断位状态
- DAEMON: 是否是 daemon 线程
stack:输出当前方法被调用的调用路径
1 | watch com.zhixi.demos.web.BasicController hello '{params,returnObj,throwExp}' -n 5 -x 3 |
命令的具体含义如下:
1 2 3 4 5 6 7 8 9 | watch:执行监视命令。 com.zhixi.demos.web.BasicController hello:指定要监视的Java方法,com.zhixi.demos.web.BasicController是类的全名,hello是方法名。 '{params,returnObj,throwExp}' :指定要监视的方法参数、返回值和异常信息。 params 表示方法的参数信息,会显示参数的类型和值。 returnObj表示方法的返回值信息,会显示返回值的类型和值。 throwExp表示方法抛出的异常信息,会显示异常的类型和消息。 -n 5:指定监视的次数,这里设置为5次。 -x 3:指定每次监视的间隔时间,这里设置为3秒。 总结起来,这个命令的作用是每3秒监视一次com.zhixi.demos.web.BasicController类中的hello方法,打印方法的参数、返回值和异常信息,总共监视5次。 |
trace:方法内部调用路径,并输出方法路径上的每个节点上耗时
1 | trace com.zhixi.demos.web.BasicController hello -n 5 --skipJDKMethod false |
参数解释如下:
trace
:命令本身,用于启动追踪。com.zhixi.demos.web.BasicController
:要追踪的类的全限定名,这里是BasicController
类所在的包路径。hello
:要追踪的方法名,这里是BasicController
类中的hello
方法。-n 5
:执行追踪的次数,这里设置为 5 次。--skipJDKMethod false
:是否跳过 JDK 自带方法的追踪,这里设置为不跳过 JDK 方法。
tt:方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测
1 2 3 4 5 6 7 8 9 10 | # 记录调用 tt -t com.zhixi.demos.web.BasicController user -n 5 # 检索调用记录 tt -l # 查看调用信息 tt -i [index] # 重新执行调用 tt -p -i [index] # 指定调用测试为5次 tt -p --replay-times 5 -i [index] |
- "tt":表示要运行的命令行工具名称。
- "-t com.zhixi.demos.web.BasicController":指定要测试的Java类的全限定名为"com.zhixi.demos.web.BasicController"。
- "user":表示要测试的方法名为"user"。
- "-n 5":表示要运行测试用例的次数,这里设置为5次。这意味着该测试用例会运行5次以检查方法的稳定性和正确性等方面的性能。
ognl:执行 ognl 表达式
查看/设置静态变量:
1 2 3 4 | # 查看静态属性值 ognl -x 3 '@com.zhixi.demos.web.BasicController@STATE' # 重新设置静态属性值 ognl -x 3 '#field=@com.zhixi.demos.web.BasicController@class.getDeclaredField("STATE"),#field.setAccessible(true),#field.set(null,"新属性值")' |
retransform:热更新代码
文档地址:https://arthas.aliyun.com/doc/retransform.html#retransform
retransform使用限制:
- 不允许新增加 field/method
- 正在跑的函数,没有退出不能生效,比如下面新增加的
System.out.println
,只有run()
函数里的会生效
需求:动态修改方法值
- 1、修改返回内容
- 2、增加日志打印
1 2 3 4 5 | @RequestMapping( "/hello" ) @ResponseBody public String hello(@RequestParam(name = "name" , defaultValue = "unknown user" ) String name) { return "Hello" + name; } |
修改成下面的内容:
1 2 3 4 5 6 | @RequestMapping( "/hello" ) @ResponseBody public String hello(@RequestParam(name = "name" , defaultValue = "unknown user" ) String name) { System. out .println( "Arthas热部署测试" ); return "Hello Arthas" + name; } |
Arthas中具体操作
1、正常访问请求接口
2、IDEA修改controller,并重新编译
3、将编译后的文件上传到服务器(目录随意)
4、启动Arthas重新对class进行修改
1 | [arthas@20135]$ retransform /root/arthas/BasicController. class |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
2022-08-11 读取resources下的资源