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

相关推荐
不懒不懒17 小时前
【HTML容器与表格布局实战指南】
java·开发语言
J_liaty17 小时前
Java实现PDF添加水印的完整方案(支持灵活配置、平铺、多页策略)
java·开发语言·pdf
一路向北⁢17 小时前
Spring Boot 3 整合 SSE (Server-Sent Events) 企业级最佳实践(二)
java·数据库·spring boot·sse·通信
chilavert31817 小时前
技术演进中的开发沉思-349:高效并发(下)
java·jvm
shejizuopin17 小时前
基于SSM的高校旧书交易系统的设计与实现(任务书)
java·mysql·毕业设计·论文·任务书·基于ssm的·高校旧书交易系统的设计与实现
好好研究17 小时前
SpringBoot使用外置Tomcat
spring boot·后端·tomcat
1candobetter17 小时前
JAVA后端开发——Spring Boot 组件化自动配置机制
java·开发语言·spring boot
索荣荣17 小时前
Spring Boot 实现DOCX转PDF(基于docx4j的轻量级开源方案)
spring boot·后端·pdf
mit6.82417 小时前
[todo]10个常见的后端框架
后端
码农小卡拉17 小时前
MyBatis-Flex 全面解析与实战教程:轻量高效的 MyBatis 增强方案
java·mybatis