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

相关推荐
AI人工智能+电脑小能手5 分钟前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index
嵌入式×边缘AI:打怪升级日志7 分钟前
嵌入式Linux开发(了解交叉编译工具链的组成)
java·linux·运维
FreeGo~16 分钟前
Linux 系统编程 进程篇 (五)
java·linux·服务器
XiYang-DING36 分钟前
【Java EE】定时器
java·python·java-ee
Fuly102440 分钟前
java面试知识点复习
java·开发语言·面试
阿丰资源1 小时前
基于Spring Boot的新闻推荐系统(源码+数据库+文档)
数据库·spring boot·后端
信徒_1 小时前
API 网关技术选型
java
simple-L61 小时前
Java开发痛点技术文章大纲
java·开发语言
Gopher_HBo1 小时前
Disruptor消费源码分析
后端
千寻girling2 小时前
滑动窗口刷了快一个月(26天)了 , 还没有刷完. | 含(操作系统学什么的Java 后端)
java·开发语言·javascript·c++·人工智能·后端·python