1

Arthas

  • 是什么 Alibaba开源的java 诊断工具
  • 从哪知道的:简书-Arthas简介
  • GitHub地址:https://github.com/alibaba/arthas
  • 解决问题:

    1. 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
    2. 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
    3. 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
    4. 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
    5. 是否有一个全局视角来查看系统的运行状况?有什么办法可以监控到JVM的实时运行状态?

安装

  • 环境 mac OSX
  • 采取安装方式:一键安装(安装方法见官方文档)
  • 安装结果:

clipboard.png

使用

  1. 直接在shell下面执行./as.sh,进入交互界面

  2. 输入进程号,选择要诊断的进程

相关命令

  • help——查看命令帮助信息

clipboard.png

  • dashboard ——实时数据面板

clipboard.png

  • thread —— 查看线程信息

    • 没有线程数,显示所有线程

      clipboard.png

    • 带线程数 ,显示该线程栈信息

      clipboard.png

  • jad ——反编译加载类

clipboard.png

  • watch ——数据观测

clipboard.png

命令列表

  • 基础命令

    • help——查看命令帮助信息
    • cls——清空当前屏幕区域
    • session——查看当前会话的信息
    • reset——重置增强类,将被 Arthas 增强过的类全部还原,Arthas 服务端关闭时会重置所有增强过的类
    • version——输出当前目标 Java 进程所加载的 Arthas 版本号
    • history——打印命令历史
    • quit——退出当前 Arthas 客户端,其他 Arthas 客户端不受影响
    • shutdown——关闭 Arthas 服务端,所有 Arthas 客户端全部退出
    • keymap——Arthas快捷键列表及自定义快捷键
  • jvm相关

    • dashboard——当前系统的实时数据面板
    • thread——查看当前 JVM 的线程堆栈信息
    • jvm——查看当前 JVM 的信息
    • sysprop——查看和修改JVM的系统属性
    • sysenv——查看JVM的环境变量
    • getstatic——查看类的静态属性
    • New! ognl——执行ognl表达式
  • class/classloader相关

    • sc——查看JVM已加载的类信息
    • sm——查看已加载类的方法信息
    • dump——dump 已加载类的 byte code 到特定目录
    • redefine——加载外部的.class文件,redefine到JVM里
    • jad——反编译指定已加载类的源码
    • classloader——查看classloader的继承树,urls,类加载信息,使用classloader去getResource
  • monitor/watch/trace相关
    请注意,这些命令,都通过字节码增强技术来实现的,会在指定类的方法中插入一些切面来实现数据统计和观测,因此在线上、预发使用时,请尽量明确需要观测的类、方法以及条件,诊断结束要执行

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

    • options——查看或设置Arthas全局开关

carol_gao
88 声望1 粉丝