Arthas 介绍

一 点睛

一般的 JVM 监控工具都必须在服务端项目进程中配置相关的监控参数,然后工具通过远程连接到项目进程,获取相关的数据。这样就会带来一些不便,比如线上环境的网络是隔离的,本地的监控工具根本连不上线上环境。并且类似于 Jprofiler 这样的商业工具,是需要付费的。

那么有没有一款工具不需要远程连接,也不需要配置监控参数,同时也提供了丰富的性能监控数据呢?

阿里巴巴开源的性能分析神器 Arthas 应运而生。

Arthas 是 Alibaba 开源的 Java 诊断工具,深受开发者喜爱。

在线排查问题,无需重启。

动态跟踪 Java 代码。

实时监控 JVM 状态。

Arthas 支持 JDK 6 +,支持 Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。当你遇到以下类似问题而束手无策时,Arthas 可以帮助你解决。

  • 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?

  • 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?

  • 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?

  • 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!

  • 是否有一个全局视角来查看系统的运行状况?

  • 有什么办法可以监控到 JVM 的实时运行状态?

  • 怎么快速定位应用的热点,生成火焰图?

二 官方地址

https://arthas.aliyun.com/doc/quick-start.html

三 安装方式

如果速度较慢,可以尝试国内的码云 Gitee 下载。

wget https://io/arthas/arthas-boot.jar

wget https://arthas/gitee/io/arthas-boot.jar

Arthas 只是一个 java 程序,所以可以直接用 java -jar 运行。

除了在命令行查看外,Arthas 目前还支持 Web Console。在成功启动连接进程之后就已经自动启动,可以直接访问 http://127.0.0.1:8563/ 访问,页面上的操作模式和控制台完全一样。

四 基础指令

quit/exit 退出当前 Arthas客户端,其他 Arthas喜户端不受影响

stop/shutdown 关闭 Arthas服务端,所有 Arthas客户端全部退出

help 查看命令帮助信息

cat 打印文件内容,和l inux 里的 cat 命令类似

echo 打印参数,和 linux 里的 echo 命令类似

grep 匹配查找,和 linux 里的 grep 命令类似

tee 复制标隹输入到标准输出和指定的文件,和 linux 里的 tee 命令类似

pwd 返回当前的工作目录,和 linux 命令类似

cs 清空当前屏幕区域

session 查看当前会话的信息

reset 重置增强类,将被 Arthas 增强过的类全部还原, Arthas 服务端关闭时会重置所有增强过的类

version 输出当前目标 Java 进程所加载的 Arthas 版本号

history 打印命令历史

keymap Arthas 快捷键列表及自定义快捷键

五 jvm 相关

dashboard 当前系统的实时数据面板

thread 查看当前 JVM 的线程堆栈信息

jvm 查看当前 JVM 的信息

sysprop 查看和修改 JVM 的系统属性

system 查看 JVM 的环境变量

vmoption 查看和修改 JVM 里诊断相关的 option

perfcounter 查看当前 JVM 的 Perf Counter 信息

logger 查看和修改 logger

getstatic 查看类的静态属性

ognl 执行 ognl 表达式

mbean 查看 Mbean 的信息

heapdump dump java heap,类似 jmap 命令的 heap dump 功能

六 class/classloader 相关

sc 查看 JVM 已加载的类信息

-d 输出当前类的详细信息,包括这个类所加载的原始文件来源、类的声明、加载的 Classloader 等详细信息。如果一个类被多个 Classloader 所加载,则会出现多次。

-E 开启正则表达式匹配,默认为通配符匹配

-f 输出当前类的成员变量信息(需要配合参数 -d 一起使用)

-X 指定输出静态变量时属性的遍历深度,默认为0,即直接使用 toString 输出

sm 查看已加载类的方法信息

-d 展示每个方法的详细信息

-E 开启正则表达式匹配,默认为通配符匹配

jad 反编译指定已加载类的源码

mc 内存编译器,内存编译 .java 文件为 .class 文件

retransform 加载外部的 .class 文件, retransform 到 JVM里

redefine 加载外部的 .class文件,redefine 到 JVM里

dump dump 已加载类的 byte code 到特定目录

classloader 查看 classloader 的继承树,urts,类加载信息,使用 classloader 去 getResource

-t 查看classloader的继承树

-l 按类加载实例查看统计信息

-c 用 classloader 对应的 hashcode 来查看对应的 Jar urls

七 monitor/watch/trace 相关

monitor 方法执行监控,调用次数、执行时间、失败率

-c 统计周期,默认值为120秒

watch 方法执行观测,能观察到的范围为:返回值、抛出异常、入参,通过编写 groovy 表达式进行对应变量的查看

-b 在方法调用之前观察(默认关闭)

-e 在方法异常之后观察(默认关闭)

-s 在方法返回之后观察(默认关闭)

-f 在方法结束之后(正常返回和异常返回)观察(默认开启)

-x 指定输岀结果的属性遍历深度,默认为0

trace 方法内部调用路径,并输出方法路径上的每个节点上耗时

-n 执行次数限制

stack 输出当前方法被调用的调用路径

tt 方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测

八 其他

jobs 列出所有job

kill 强制终止任务

fg 将暂停的任务拉到前台执行

bg 将暂停的任务放到后台执行

grep 搜索满足条件的结果

plaintext 将命令的结果去除 ANSI 颜色

wc 按行统计输出结果

options 查看或设置Arthas全局开关

profiler 使用async-profiler对应用采样,生成火焰图

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值