JVM学习(四):Arthas的安装与使用

人生之路不会是一帆风顺的,我们会遇上顺境,也会遇上逆境,在所有成功路上折磨你的,背后都隐藏着激励你奋发向上的动机,人生没有如果,只有后果与结果,成熟,就是用微笑来面对一切小事。

导读:本篇文章讲解 JVM学习(四):Arthas的安装与使用,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

一、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

        快速入门 | arthas

3.2 Web console

        除了在命令行查看外,Arthas目前还支持 web Console。在成功启动连接进程之后就已经自动启动,可以直接访问http://127.0.0.1:8563/访问,页面上的操作模式和控制台完全一样。

四、相关诊断指令

        命令列表 | arthas

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 相关

  • monitor – 方法执行监控
  • stack – 输出当前方法被调用的调用路径
  • trace – 方法内部调用路径,并输出方法路径上的每个节点上耗时
  • tt – 方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测
  • watch – 方法执行数据观测

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/124940.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!