一、Arthas概述
1.1 为什么要使用Arthas
我们本身已经有Jvisualvm和Jprofiler,这两款工具在业界知名度也比较高,他们的优点是可以图形界面上看到各维度的性能数据,使用者根据这些数据进行综合分析,然后判断哪里出现了性能问题。
但是这两款工具也有缺点,都必须在服务端项目进程中配置相关的监控参数。然后工具通过远程连接到项目进程,获取相关的数据。这样就会带来一些不便,比如线上环境的网络是隔离的,本地的监控工具根本连不上线上环境。并且类似于Jprofiler这样的商业工具,是需要付费的。
那么有没有一款工具不需要远程连接,也不需要配置监控参数,同时也提供了丰富的性能监控数据呢?
这就需要介绍一款阿里巴巴开源的性能分析神器Arthas(阿尔萨斯)。
1.2 什么是Arthas
Arthas(阿尔萨斯)是Alibaba开源的Java诊断工具,深受开发者喜爱。在线排查问题,无需重启;动态跟踪Java代码;实时监控JVM状态。
Arthas 支持JDK 6+,支持Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab自动补全功能,进一步方便进行问题的定位和诊断。
官方使用文档:https://arthas.aliyun.com/doc/quick-start.html
二、Arthas的安装
可参考官方文档:Arthas Install | arthas
2.1 方法一:
直接在Linux上安装:
可以在官方Github 上进行下载,如果速度较慢,可以尝试国内的码云 Gitee下载。
github下载:
wget https://alibaba.github.io/arthas/arthas-boot.jar
Gitee 下载:
wget https://arthas.gitee.io/arthas-boot.jar
2.2 方式二:
也可以在浏览器直接访问 https://alibaba.github.io/arthas/arthas-boot.jar,等待下载成功后,上传到Linux服务器上。
2.3 工程目录
- arthas-agent:基于JavaAgent技术的代理
- bin:一些启动脚本
- arthas-boot: Java版本的一键安装启动脚本
- arthas-client: telnet client代码
- arthas-common:一些共用的工具类和枚举类
- arthas-core:核心库,各种arthas命令的交互和实现
- arthas-demo:示例代码
- arthas-memorycompiler:内存编绎器代码,Fork from https://github.com/skalogs/SkaETL/tree/master/compiler
- arthas-packaging: maven打包相关的
- arthas-site: arthas站点
- arthas-spy:编织到目标类中的各个切面
- static:静态资源
- arthas-testcase:测试
三、Arthas的使用
3.1 启动Arthas
3.2 Web console
除了在命令行查看外,Arthas目前还支持 web Console。在成功启动连接进程之后就已经自动启动,可以直接访问http://127.0.0.1:8563/访问,页面上的操作模式和控制台完全一样。
四、相关诊断指令
4.1 基础命令
- base64 – base64 编码转换,和 linux 里的 base64 命令类似
- cat – 打印文件内容,和 linux 里的 cat 命令类似
- cls – 清空当前屏幕区域
- echo – 打印参数,和 linux 里的 echo 命令类似
- grep – 匹配查找,和 linux 里的 grep 命令类似
- help – 查看命令帮助信息
- history – 打印命令历史
- keymap – Arthas 快捷键列表及自定义快捷键
- pwd – 返回当前的工作目录,和 linux 命令类似
- quit – 退出当前 Arthas 客户端,其他 Arthas 客户端不受影响
- reset – 重置增强类,将被 Arthas 增强过的类全部还原,Arthas 服务端关闭时会重置所有增强过的类
- session – 查看当前会话的信息
- stop – 关闭 Arthas 服务端,所有 Arthas 客户端全部退出
- tee – 复制标准输入到标准输出和指定的文件,和 linux 里的 tee 命令类似
- version – 输出当前目标 Java 进程所加载的 Arthas 版本号
4.2 JVM相关
- dashboard – 当前系统的实时数据面板
- getstatic – 查看类的静态属性
- heapdump – dump java heap, 类似 jmap 命令的 heap dump 功能
- jvm – 查看当前 JVM 的信息
- logger – 查看和修改 logger
- mbean – 查看 Mbean 的信息
- memory – 查看 JVM 的内存信息
- ognl – 执行 ognl 表达式
- perfcounter – 查看当前 JVM 的 Perf Counter 信息
- sysenv – 查看 JVM 的环境变量
- sysprop – 查看和修改 JVM 的系统属性
- thread – 查看当前 JVM 的线程堆栈信息
- vmoption – 查看和修改 JVM 里诊断相关的 option
- vmtool – 从 jvm 里查询对象,执行 forceGc
4.3 class/classloader 相关
- classloader – 查看 classloader 的继承树,urls,类加载信息,使用 classloader 去 getResource
- dump – dump 已加载类的 byte code 到特定目录
- jad – 反编译指定已加载类的源码
- mc – 内存编译器,内存编译
.java
文件为.class
文件 - redefine – 加载外部的
.class
文件,redefine 到 JVM 里 - retransform – 加载外部的
.class
文件,retransform 到 JVM 里 - sc – 查看 JVM 已加载的类信息
- sm – 查看已加载类的方法信息
4.4 monitor/watch/trace 相关
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/124940.html