arthas 我愿称为最强辅助工具

Arthas (注意拼写是 Arthas ,不是 Arthus),是由阿里巴巴开源的一款 Java 诊断工具 ,专为在线排查 Java 应用问题而设计。它功能强大、使用方便,支持在不修改代码、不重启服务的情况下,对运行中的 Java 应用进行实时诊断。官网地址[arthas.aliyun.com/]

✅ 使用场景

  • 线上服务 CPU 飙高,快速定位热点方法
  • 接口响应慢,分析调用链耗时
  • 验证线上代码是否为最新版本(通过 jad 反编译)
  • 查看某个方法的实际入参/返回值(无需加日志重启)
  • 排查死锁、内存泄漏、类加载问题等

🚀 快速开始

bash 复制代码
bash
编辑
# 下载 arthas-boot.jar
curl -O https://arthas.aliyun.com/arthas-boot.jar

# 启动(会列出所有 Java 进程)
java -jar arthas-boot.jar

# 选择目标进程 PID,进入交互式命令行

idea使用插件推荐: arthas idea

常用命令

dashboard Overview of target jvm's thread, memory, gc, vm, tomcat info.

thread thread 线程编号

jad class Decompile class 反编译类 看线上代码是否已经部署最新

watch com.response.PriceApiResponse * '{params,returnObj,throwExp}' -n 5 -x 3 检测方法入参/出参/异常

trace com.service.impl.AuditServiceImpl commit -n 5 --skipJDKMethod false 对方法耗时进行统计

stack com.admin.dto.request.AuditData * -n 5 调用栈 看什么地方会调用此方法

monitor com.admin.dto.request.AuditData * -n 10 --cycle 10 一般压测的时候使用 查看调用次数成功和失败数量

线上使用

死循环导致cpu飙高

thread -n 1 线程使用率最高的一个 定位哪一行代码造成的cup飙高

死锁

thread 查看死锁线程数 BLOCKED是死锁线程数量

thread -b 直接查看死锁信息 抢占什么死锁资源 \

时空隧道

tt -t com.admin.dto.request.AuditData * -n 5 记录方法调用

tt -i 1000 查看1000访问时候的请求参数 返回值 异常等信息 tt -p -i 1000 回放重新调用 显示返回值 异常信息等

相关推荐
用户0844652563710 小时前
Docker 部署 MongoDB Atlas 到服务端
后端
风生u10 小时前
activiti7 详解
java
岁岁种桃花儿10 小时前
SpringCloud从入门到上天:Nacos做微服务注册中心(二)
java·spring cloud·微服务
Word码11 小时前
[C++语法] 继承 (用法详解)
java·jvm·c++
TT哇11 小时前
【实习 】银行经理端两个核心功能的开发与修复(银行经理绑定逻辑修复和线下领取扫码功能开发)
java·vue.js
逝水如流年轻往返染尘11 小时前
Java中的数组
java
Anita_Sun11 小时前
一看就懂的 Haskell 教程 - 类型推断机制
后端·haskell
java1234_小锋11 小时前
Java高频面试题:BIO、NIO、AIO有什么区别?
java·面试·nio
Anita_Sun11 小时前
一看就懂的 Haskell 教程 - 类型签名
后端·haskell
七八星天11 小时前
C#代码设计与设计模式
后端