文档地址
https://alibaba.github.io/arthas/install-detail.html
开始安装
- 我本地就装window版本了,下载zip包
- 按照快速入门,编译demo程序,运行watch后
可以看到watch可以直接拿到正在运行的方法返回值 - dashboard命令用来查看进程基本信息
4.monitor -c 5 Demo hehe
import java.util.*;public class Demo {public static void main(String[] args) {List<String> list = new ArrayList<String>();list.add("a");list.add("b");List<String> list2 = new ArrayList<String>();list2.add("c");list2.add("d");int len = add(list, list2);}private static int add(List<String> list, List<String> list2) {int i = 100;while (i >= 0) {try {hehe(i);Thread.sleep(2000);} catch (Throwable t) {t.printStackTrace();}i--;}list.addAll(list2);return list.size();}private static void hehe(int i) {if (i == 0) {throw new RuntimeException("ZERO");}haha(i);}private static void haha(int i){}
}
可以看出monitor可以查看方法调用频率和成功失败情况
- trace Demo hehe
它展示的是方法的深层次调用和调用时间 - watch Demo hehe {params[0],throwExp} -e
观察方法执行入参 - tt -t Demo hehe
记录方法调用信息,支持事后查看方法调用的参数,返回值,抛出的异常等信息,仿佛穿越时空隧道回到调用现场一般。 - classloader
当前系统中有多少类加载器,以及每个加载器加载的类数量 - jad Demo
可以看到,改命令能==反编译类==,线上看代码不是梦,个人觉得这个最实用了 - sc -d Demo
查看类的继承关系等 - stack Demo
查看栈信息