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 回放重新调用 显示返回值 异常信息等

相关推荐
云原生指北2 小时前
GitHub Copilot SDK 入门:五分钟构建你的第一个 AI Agent
java
Leinwin6 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
薛定谔的悦6 小时前
MQTT通信协议业务层实现的完整开发流程
java·后端·mqtt·struts
enjoy嚣士7 小时前
springboot之Exel工具类
java·spring boot·后端·easyexcel·excel工具类
罗超驿7 小时前
独立实现双向链表_LinkedList
java·数据结构·链表·linkedlist
无限大67 小时前
职场逻辑03:3步搞定高效汇报,让领导看到你的价值
后端
盐水冰8 小时前
【烘焙坊项目】后端搭建(12) - 订单状态定时处理,来单提醒和顾客催单
java·后端·学习
凸头8 小时前
CompletableFuture 与 Future 对比与实战示例
java·开发语言
wuqingshun3141598 小时前
线程安全需要保证几个基本特征
java·开发语言·jvm
紫丁香8 小时前
AutoGen详解一
后端·python·flask