Arthas 服务监控

Arthas

Arthas是阿里巴巴中间件团队开源的Java诊断工具。它在阿里巴巴内部的开发者中被广泛采用和流行。Arthas帮助开发人员在基于Java的应用程序的生产环境中排除问题,而无需修改代码或重新启动服务器

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

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

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

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

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

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

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

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

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

 

提供性能看板,包括线程、cpu、内存等信息,并且会定时的刷新。

根据各种条件查看线程快照。比如找出cpu占用率最高的n个线程等

输出jvm的各种信息,如gc算法、jdk版本、ClassPath

查看/设置syspropsysenv

查看某个类的静态属性,也可以通过ognl语法执行一些语句

查看已加载的类的详细信息,比如这个类从哪个jar包加载的。也可以查看类的方法的信息

dump某个类的字节码到指定目录

直接反编译指定的类

查看类加载器的一些信息

可以让jvm重新加载某个类

监控方法的执行,同时可以获取到执行的入参、出参以及抛出的异常

追踪方法执行的调用栈,以及各个方法的调用时间

 

Arthas Install

快速安装

推荐使用 arthas-boot

下载arthas-boot.jar,然后用java -jar的方式启动

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

java -jar arthas-boot.jar

如果下载速度比较慢,可以使用aliyun的镜像:

curl -L https://arthas.aliyun.com/install.sh | sh

启动命令:

java -jar arthas-boot.jar

输入想要诊断的项目对应数字1

Arthas启动成功

 

一.dashboard命令

 

输入dashboard回车/enter,会展示当前进程的信息,按ctrl+c可以中断执行。

 

进入当前系统的实时数据面板,按 ctrl+c 退出。这个面板会实时刷新,其中包括线程信息、内存信息、gc信息、还有一些运行时的数据。
另外,当运行在Ali-tomcat时,会显示当前tomcat的实时信息,如HTTP请求的qps, rt, 错误数, 线程池信息等等。

 

 

 

 

二.thread命令

 

通过thread命令可以查看当前jvm进程的线程详情。可以查看线程的cpu使用时间占比,通过指定各种参数可以找出最忙的几个线程,以及阻塞其他线程的线程。具体如何使用这里不多做介绍,大家可以去看arthas的官方文档。

 

thread命令查看全部线程信息

 

thread1 指定查看线程id

 

thread-n 3 展示当前最忙的3个线程展示堆栈

 

thread-b  找出当前阻塞其他线程的线程

 

thread--state WAITING 查看所有等待的线程

 获取指定线程的详细信息

 

 

 三.jad命令

 

Arthas jad 命令指定反编译类

jad com.xxx.xxx.xxx.entity.StartAppImg

jad 路径.类名

posted @ 2021-11-16 18:24  RunawayProgrammer  阅读(1309)  评论(0编辑  收藏  举报