【Arthas-Java 诊断工具使用简介】

1 Arthas简介
Arthas 是 Alibaba 在 2018 年 9 月开源的 Java 诊断工具。支持 JDK6+, 采用命令行交互模式,可以方便的定位和诊断
线上程序运行问题。Arthas 官方文档十分详细,详见:arthas
2 Arthas使用场景
得益于 Arthas 强大且丰富的功能,让 Arthas 能做的事情超乎想象。下面仅仅列举几项常见的使用情况,更多的使用场
景可以在熟悉了 Arthas 之后自行探索。
1. 是否有一个全局视角来查看系统的运行状况?
2. 为什么 CPU 又升高了,到底是哪里占用了 CPU ?
3. 运行的多线程有死锁吗?有阻塞吗?
4. 程序运行耗时很长,是哪里耗时比较长呢?如何监测呢?
5. 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
6. 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
7. 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
8. 有什么办法可以监控到 JVM 的实时运行状态?
3 Arthas使用
1 首先复制下方代码并启动

public class Arthas {
    private static HashSet hashSet = new HashSet();

     public static void main(String[] args) {
            // 模拟 CPU 过高
            cpuHigh();
            // 模拟线程死锁
            deadThread();
            // 不断的向 hashSet 集合增加数据
            addHashSetThread();
        }

    /**
     * 不断的向 hashSet 集合添加数据
     */
     public static void addHashSetThread() {
        // 初始化常量
         new Thread(()->{
             int count = 0;
             while (true) {
                 try {
                     hashSet.add("count" + count);
                     Thread.sleep(1000);
                     count++;
                 } catch (InterruptedException e) {
                     e.printStackTrace();
                 }
             }
         }).start();
     }

    /**
     * 死循环
     */
    public static void cpuHigh() {
         new Thread(()->{
             while (true) {

             }
         }).start();
    }

    /**
     * 死锁
     */
    private static void deadThread() {
        /** 创建资源 */
        Object resourceA = new Object();
        Object resourceB = new Object();
        // 创建线程
        Thread threadA = new Thread(()->{
            synchronized (resourceA) {
                System.out.println(Thread.currentThread() + " get ResourceA");
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println(Thread.currentThread() + "waiting get resourceB");
                synchronized (resourceB) {
                    System.out.println(Thread.currentThread() + " get resourceB");
                }
            }
        });
        Thread threadB = new Thread(()->{
            synchronized (resourceB) {
                System.out.println(Thread.currentThread() + " get ResourceB");
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println(Thread.currentThread() + "waiting get resourceA");
                synchronized (resourceA) {
                    System.out.println(Thread.currentThread() + " get resourceA");
                }
            }
        });
        threadA.start();
        threadB.start();
    }
}

2 # github下载arthas
wget https://alibaba.github.io/arthas/arthas‐boot.jar
3 # 或者 Gitee 下载
wget https://arthas.gitee.io/arthas‐boot.jar
用java -jar运行即可,可以识别机器上所有Java进程(我们启动代码进程)
 

image.png


选择对应进程序号,进入进程信息操作

image.png


输入dashboard可以查看整个进程的运行情况,线程、内存、GC、运行环境信息:

image.png


输入thread可以查看线程详细情况

image.png


输入 thread加上线程ID 可以查看线程堆栈
 

image.png


输入 thread -b 可以查看线程死锁
 

image.png


输入 jad加类的全名 可以反编译,这样可以方便我们查看线上代码是否是正确的版本
 

image.png


使用 ognl 命令可以查看线上系统变量的值,甚至可以修改变量的值
 

image.png


4 Arthas更多命令
更多命令使用可以用help命令查看,或查看文档:https://alibaba.github.io/arthas/commands.html#arthas

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值