Arthas的使用

Arthas是一款由Alibaba开源的Java诊断工具,它帮助开发者解决类加载、代码执行、线上调试等问题。通过命令行交互模式,提供Tab自动补全功能,支持观察方法调用、监控JVM状态、生成火焰图等功能。当遇到前端与后端交互故障、线上调试难题时,Arthas能有效辅助定位问题。

1.简介

官网:https://arthas.aliyun.com/zh-cn/

Arthas 是Alibaba开源的Java诊断工具,深受开发者喜爱。

当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:

  1. 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?

  2. 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?

  3. 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?

  4. 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!

  5. 是否有一个全局视角来查看系统的运行状况?

  6. 有什么办法可以监控到JVM的实时运行状态?

  7. 怎么快速定位应用的热点,生成火焰图?

  8. 怎样直接从JVM内查找某个类的实例?

Arthas支持JDK 6+,支持Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。

以上是官网的介绍。

本人是因为一个测试的一个bug认识了Arthas。前端说调用接口了,但是后端却没有日志打印,怀疑是前端根本没调用。为了证明错误到底在谁,使用Arthas去找内奸。

2.安装与使用

1.下载

curl -O https://arthas.aliyun.com/arthas-boot.jar

使用该命令在当前目录下载Arthas的jar包:arthas-boot.jar

2.使用

启动方式:java -jar arthas-boot.jar

注意启动前需要服务器有运行状态的Java服务(没有服务运行的话Arthas去监听谁呢?)。

启动成功后,Arthas会让你选择需要监听的服务,按下需要监听服务对应的数字键,然后回车即可进入Arthas的命令行界面。

常用命令:

watch:让你能方便的观察到指定方法的调用情况。能观察到的范围为:返回值抛出异常入参,通过编写 OGNL 表达式进行对应变量的查看。

例子:监听TestController下test()方法的出入参数

watch com.example.demo.controller.TestController test "{params,target,returnObj}" -s -b -x:3

以上,更多使用方式参考官方文档即可。

### 使用 Arthas 工具分析 Java 应用中 CPU 占用最高的线程 在 Java 应用开发过程中,遇到 CPU 占用过高时,可以使用 Arthas 工具进行快速定位和分析。以下是具体方法: #### 启动 Arthas 在服务器上启动 Arthas 工具,执行以下命令: ```bash java -jar arthas-boot.jar ``` 运行后,工具会列出当前系统中的所有 Java 进程,选择目标进程对应的序号即可进入 Arthas 命令行界面[^1]。 #### 查看 CPU 占用最高的线程 进入 Arthas 命令行后,可以使用 `thread` 命令查看线程的 CPU 占用情况。例如,输入以下命令可以列出 CPU 占用率最高的三个线程: ```bash thread -n 3 ``` 该命令会输出占用 CPU 最高的三个线程的详细信息,括线程 ID、线程名称以及堆栈信息。通过这些信息可以快速定位到导致 CPU 占用过高的代码位置[^2]。 #### 深入分析线程状态 如果需要进一步分析某个特定线程的状态,可以使用 `thread <线程ID>` 命令。例如: ```bash thread 123 ``` 上述命令会输出线程 ID 为 123 的线程的详细堆栈信息,帮助开发者更深入地理解线程的行为[^3]。 #### 监控 Java 程序运行状态 除了 `thread` 命令外,还可以使用 `dashboard` 命令实时监控 Java 程序的运行状态,括 CPU 使用率、内存使用情况等。执行以下命令: ```bash dashboard ``` 该命令会以秒级刷新频率显示程序的运行指标,便于开发者全面了解应用的性能状况[^2]。 #### 示例:制造并排查 CPU 占用 100% 的场景 以下是一个 Spring Boot 应用中的示例代码,用于模拟 CPU 占用 100% 的情况: ```java @RequestMapping("/lock") public void lock() { System.out.println("开始死锁操作。。。。"); StringBuffer stringBuffer = new StringBuffer(); while (true) { String uuid = UUID.randomUUID().toString(); } } ``` 通过访问 `/lock` 接口触发死循环逻辑,然后使用 Arthas 工具定位问题线程。结合 `thread` 和 `dashboard` 命令,可以快速找到导致 CPU 占用过高的代码位置[^2]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值