Arthas的使用

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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使用指南 #### 什么是 ArthasArthas 是一款用于线上监控和诊断的应用程序,能够实时查看应用负载、内存状态、垃圾回收 (GC) 和线程运行情况等信息[^1]。 它还提供了无需修改代码即可对方法调用参数、返回值以及异常情况进行分析的功能。 #### 平台兼容性和启动方式 Arthas 支持 JDK 6 及以上版本,并适用于多种操作系统环境(Linux/Mac/Windows),其操作界面基于命令行并具备 Tab 键自动补全功能,极大地方便了用户的日常使用[^3]。 ##### 快速入门实例 以下是快速体验 Arthas 功能的一个简单流程: 1. **下载 Math Game 示例项目** 首先可以通过如下指令获取 `math-game` 测试文件: ```bash curl -O https://arthas.aliyun.com/math-game.jar ``` 2. **运行 Math Game** 接下来利用 Java 命令来启动该 jar 文件: ```bash java -jar math-game.jar ``` 3. **启动 Arthas 工具** 在另一个终端会话中按照下面的方式安装并初始化 Arthas: ```bash bash <(curl -s https://alibaba.github.io/arthas/install.sh) ``` 此外也可以直接指定目标进程 ID 来连接到已有的 JVM 实例上进行调试[^3]。 #### 批量命令执行技巧 为了提高工作效率或者实现自动化脚本需求时可以考虑采用批处理模式下的 Arthas 调用形式。例如创建一个含多个待执行语句的文本文档 `/tmp/commands.txt` ,内容形如: ``` thread -n 3 dashboard ``` 随后借助 `-b` 参数配合此配置完成一系列预定义动作的操作过程演示: ```bash echo "thread -n 3\ndashboard" > /tmp/commands.txt java -jar arthas-boot.jar -b -f /tmp/commands.txt ``` 这样不仅可以减少重复劳动还能有效缩短响应时间从而达到更优的效果展示目的[^4]。 #### 方法监视案例分享 如果希望了解某个特定函数内部的工作机制,则可运用内置插件中的 `watch` 子命令达成这一目标。比如针对某服务接口内的具体逻辑片段实施全程跟踪记录的话就可以参照下述示范代码来进行设置部署工作: ```bash watch com.example.MyService myMethod '{params, returnObj}' -x 2 ``` 这里需要注意的是实际路径应当替换为你自己项目的名与对应的方法签名表达式等内容项以便于精准匹配所需观察的目标对象实体个体单元部分位置区域范围等方面的信息资料数据等等[^5]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值