🪂Arthas监控

Captain / 2023-08-11 / 原文

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:当前系统的实时数据面板

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 线程

 

 

ognl:执行 ognl 表达式

查看/设置静态变量:

# 查看静态属性值
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,"新属性值")'