阿里巴巴开源的 Java 诊断工具Arthas【入门篇】

4,243 阅读2分钟

前面:

各位老铁们,好久没和大家见面了,最近2B哥一直躲在家里不敢出来门,过着像猪的生活.....

吃喝拉撒睡觉。远程在家办公一段时间也是遇到了比较棘手的问题。所以没有顾得上来和大家分享了,不过大家放心,2B哥从这篇文章起我又会回到正轨了(XXXX,必有后福)哈哈哈同意的点个赞哈~~~~

Arthas简介

Arthas(阿尔萨斯)是阿里巴巴开源的 Java 诊断工具,开始在淘宝内部孵化使用,后来成为阿里java项目必须使用的内部工具。2018年arthas成为ali开源项目,代码托管在github上。这是带给java系一大福音,项目深受开发者喜爱。

官网地址:alibaba.github.io/arthas

图片

快速入门

目前最新版本为3.1.7,下载地址如下

maven.aliyun.com/repository/…

启动

./as.sh 或者输入 java -jar arthas-boot.jar (推荐)

图片

图片

这代表当前没有java进程。那怎么办了?

官方提供了一个demo我们可以进行运行起来。

图片

输入命令: java -jar arthash-demo.jar 是一个数学游戏的demo

源码如下:

package demo;

import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.concurrent.TimeUnit;

public class MathGame {
    private static Random random = new Random();

    public int illegalArgumentCount = 0;

    public static void main(String[] args) throws InterruptedException {
        MathGame game = new MathGame();
        while (true) {
            game.run();
            TimeUnit.SECONDS.sleep(1);
        }
    }

    public void run() throws InterruptedException {
        try {
            int number = random.nextInt()/10000;
            List<Integer> primeFactors = primeFactors(number);
            print(number, primeFactors);

        } catch (Exception e) {
            System.out.println(String.format("illegalArgumentCount:%3d, ", illegalArgumentCount) + e.getMessage());
        }
    }

    public static void print(int number, List<Integer> primeFactors) {
        StringBuffer sb = new StringBuffer(number + "=");
        for (int factor : primeFactors) {
            sb.append(factor).append('*');
        }
        if (sb.charAt(sb.length() - 1) == '*') {
            sb.deleteCharAt(sb.length() - 1);
        }
        System.out.println(sb);
    }

    public List<Integer> primeFactors(int number) {
        if (number < 2) {
            illegalArgumentCount++;
            throw new IllegalArgumentException("number is: " + number + ", need >= 2");
        }

        List<Integer> result = new ArrayList<Integer>();
        int i = 2;
        while (i <= number) {
            if (number % i == 0) {
                result.add(i);
                number = number / i;
                i = 2;
            } else {
                i++;
            }
        }

        return result;
    }
}

这是我们在执行命令:java -jar arthas-boot.jar 就出现如下图选择自己需要查看的进程,我这儿输入1 回车,arthas就启动成功了。

图片

web控制台

通过浏览器连接arthas

Arthas目前支持Web Console,用户在attach成功之后,可以直接访问:http://127.0.0.1:3658/

可以填入IP,远程连接其它机器上的arthas。

图片

总结:

安装和下载、使用还是比较简单的,大家可以自己试试,下载下来自己玩下。大家关注下我,下篇文章教大家进阶使用。比如:

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

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

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

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

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

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

这些问题大家想了解的可以关注或者点赞给2b哥哦