arthas 我愿称为最强辅助工具

Arthas (注意拼写是 Arthas ,不是 Arthus),是由阿里巴巴开源的一款 Java 诊断工具 ,专为在线排查 Java 应用问题而设计。它功能强大、使用方便,支持在不修改代码、不重启服务的情况下,对运行中的 Java 应用进行实时诊断。官网地址[arthas.aliyun.com/](https://link.juejin.cn?target=https%3A%2F%2Farthas.aliyun.com%2F "https://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 回放重新调用 显示返回值 异常信息等

相关推荐
IT_陈寒1 天前
SpringBoot自动配置的坑,我的API突然就404了
前端·人工智能·后端
ServBay1 天前
为什么说 MCP 是 2026 年开发者必须掌握的黄金协议?
后端·mcp
程序员夏洛1 天前
Spring Boot 多模块项目中 IDEA 提示 Cannot resolve symbol 的一次排查记录
后端
子兮曰1 天前
OpenMontage 深度解剖:你的 AI 编程助手,其实是个视频工作室
前端·后端·ai编程
子兮曰1 天前
前端工具链的「Rust 化」:一场没有赢家的军备竞赛?
前端·后端·rust
爱勇宝1 天前
从 Ctrl+CV 到 Enter:程序员正在失去什么
前端·后端·程序员
码事漫谈1 天前
EdgeOne Makers + WorkBuddy:零基础也能快速搭建可上线的 AI 智能体(附图文教程)
后端
像我这样帅的人丶你还1 天前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩1 天前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构