JVM在线诊断分析工具--Arthas

2019-06-09  本文已影响0人  kopshome

Arthas是阿里开源的在线jvm诊断分析工具, 采用了命令行交互的方式进行jvm管理分析, 引用官方文档来说, 它能带给你解决以下几个问题:

GitHub地址: https://github.com/alibaba/arthas

官方文档地址: https://alibaba.github.io/arthas/install-detail.html

本文内容参考的官方文档作为学习资料, 一步一步实验而成, 所以你也可以直接查看官方文档

安装

安装方式有两种

方式一:

下载jar, 运行jar:


wget https://alibaba.github.io/arthas/arthas-boot.jar
java -jar arthas-boot.jar

方式二

此方法针对linux/mac等系统, 可以一键安装使用:


curl -L https://alibaba.github.io/arthas/install.sh | sh

此命令下载了一个shell脚本: as.sh, 直接运行此脚本即可使用! 本文使用了这种方式. 运行as.sh脚本之后, 如下图所示:

image.png

当我选择了第3个进程之后:

image.png

快速开始

仪表盘(dashboard)

展示某JVM的仪表盘(即各种指标数据), 使用命令dashboard, 接上图, 如果我要查看进程3即进程号为57732的jvm进程的仪表盘, 直接在上面的命令行中输入:


dashboard

效果如下图:

image.png

可以看到线程信息, 内存, GC次数和耗时, 系统负载, cpu核心数, java版本等.

dashboard命令运行之后, 会每隔一小段时间刷新一次, 所以想停止此命令, 请 control + c

thead

命令thread可以打印所有的线程:

image.png

输入命令后, 可以看到上图的内容, 列出了N多个线程, 线程的信息包括线程id, 线程名等等, 如果要查看某个线程, 也很简单, 只要使用thread + ID即可, 例如我要看上图中的ID为72的线程:


# thread + ID

thread 72

image.png

你也可以使用管道对命令进行过滤筛选:


# 利用管道进行线程的查找, 和linux命令风格一致

thread  | grep dubbo

反编译

运行中的应用, 如果怀疑版本更新的时候, 代码没有更新上去, 这时候经常会反编译一下代码, 查看是否是最新的代码, Arthas也提供了这样的功能, 命令为jad + 类名, 例如我要反编译springboot应用的main方法:


# 反编译测试应用的main方法

jad com.sharer.user.SharerApplication

如下图:

image.png

watch

通过watch命令查看函数的返回值, 具体的方式为: watch + 类名 + 方法名 + returnObj :


# 通过watch, 查看函数的额返回值

watch com.sharer.user.redisson getAddress returnObj

退出arthas

使用命令quiteexit可以退出arthas, 但是实际arthas会继续运行, 使用shutdown才可以完全退出

上一篇 下一篇

猜你喜欢

热点阅读