阿里开源项目arthas安装使用

文档地址

https://alibaba.github.io/arthas/install-detail.html

开始安装

  1. 我本地就装window版本了,下载zip包
  2. 按照快速入门,编译demo程序,运行watch后
    751560-20181031172427628-51602246.png 可以看到watch可以直接拿到正在运行的方法返回值
  3. dashboard命令用来查看进程基本信息
    751560-20181031173231916-238783672.png
    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){
        
    }
}

751560-20181031175301439-527821131.png
可以看出monitor可以查看方法调用频率和成功失败情况

  1. trace Demo hehe
    751560-20181031180209489-875895627.png
    它展示的是方法的深层次调用和调用时间
  2. watch Demo hehe {params[0],throwExp} -e
    751560-20181031180549971-661950474.png
    观察方法执行入参
  3. tt -t Demo hehe
    751560-20181031181148307-1575442809.png
    记录方法调用信息,支持事后查看方法调用的参数,返回值,抛出的异常等信息,仿佛穿越时空隧道回到调用现场一般。
  4. classloader
    751560-20181031181324137-1185701305.png
    当前系统中有多少类加载器,以及每个加载器加载的类数量
  5. jad Demo
    751560-20181101092656207-348026339.png
    可以看到,改命令能==反编译类==,线上看代码不是梦,个人觉得这个最实用了
  6. sc -d Demo
    751560-20181101093211640-833802592.png
    查看类的继承关系等
  7. stack Demo
    751560-20181101093458252-1321748675.png
    查看栈信息
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值