Arthas(Java 应用诊断利器)

Arthas

Arthas 是由Alibaba开源的Java监控诊断工具,通过全局视角实时查看应用 load、内存、gc、线程的状态信息,并能在不修改应用代码的情况下,对业务问题进行诊断,包括查看方法调用的出入参、异常,监测方法执行耗时,类加载信息等,大大提升线上问题排查效率。

使用背景

通常,本地开发环境无法访问生产环境。如果在生产环境中遇到问题,则无法使用 IDE 远程调试。更糟糕的是,在生产环境中调试是难以让人接受的,因为它会暂停所有线程,导致服务暂停。

开发人员可以尝试在测试环境或者预发环境中复现生产环境中的问题。但是,某些问题无法在不同的环境中轻松复现,甚至在重新启动后就消失了。

如果在代码中添加一些日志来解决问题,必须经历以下阶段:测试、预发,然后生产。这种方法效率低下,问题可能还无法解决,因为一旦 JVM 重新启动,它可能无法复现。

Arthas 旨在解决这些问题。开发人员可以在线解决生产问题。无需 JVM 重启,无需代码更改。 Arthas 作为观察者永远不会暂停正在运行的线程

Arthas(阿尔萨斯)能做什么?

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

当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:

  1. 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
  2. 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
  3. 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
  4. 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
  5. 是否有一个全局视角来查看系统的运行状况?
  6. 有什么办法可以监控到 JVM 的实时运行状态?
  7. 怎么快速定位应用的热点,生成火焰图?
  8. 怎样直接从 JVM 内查找某个类的实例?

在这里插入图片描述

Arthas 支持 JDK 6+,目前只支持 spring boot 2,支持 Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。

扫描二维码关注公众号,回复: 14554339 查看本文章

Arthas Spring Boot Starter

安装 IDEA插件

在这里插入图片描述

Arthas依赖

<dependency>
    <groupId>com.taobao.arthas</groupId>
    <artifactId>arthas-spring-boot-starter</artifactId>
    <version>3.6.3</version>
</dependency>

测试代码

@RequestMapping(value = "test")
@RestController
public class TestController {
    
    

    @GetMapping(value = "/get")
    public String get(){
    
    
        LocalDateTime now = LocalDateTime.now();
        int number = Integer.parseInt("1");
        ArrayList<String> list = new ArrayList<>();
        Map<String, String> map = new HashMap<>();
        restRequest();
        restRequest2();
        return "hello arthas";
    }

    /**
     * 模拟网络请求
     * @author: yh
     * @date: 2022/12/12
     */
    private void restRequest(){
    
    
        try {
    
    
            Thread.sleep(1000);
        } catch (InterruptedException e) {
    
    
            throw new RuntimeException(e);
        }
    }
    /**
     * 模拟网络请求
     * @author: yh
     * @date: 2022/12/12
     */
    private void restRequest2(){
    
    
        try {
    
    
            Thread.sleep(2000);
        } catch (InterruptedException e) {
    
    
            throw new RuntimeException(e);
        }
    }
}

启动后观察

在这里插入图片描述

访问:http://127.0.0.1:8563/ (调用方法即可看到方法的执行情况)

在这里插入图片描述

选择要监控的方法

在这里插入图片描述

访问接口:http://127.0.0.1:8080/test/get,观察web控制台

在这里插入图片描述

方法内的代码执行时间都被打印出来了,包括占总耗时百分比,每行消耗多长时间。按 Qctrl + c可以退出监控,对于 service 一些内部方法 或 非对web层的方法也可以监控。

单独监控一下 restRequest方法看看

在这里插入图片描述

除此之外还支持远程管理。有了这样神奇的工具,就再也不用去定义时间戳去计算方法的耗时,对于接口的性能优化提供了很便捷的一种方式。

猜你喜欢

转载自blog.csdn.net/weixin_43847283/article/details/128294591