推荐一个生产环境问题排查利器

1、是什么你是否曾遇到过生产环境出问题,但无法进行问题线上定位,只能想办法在开发环境重现问题???
Arthas是Alibaba开源的JAVA诊断工具 。
2、可以解决什么?(1)这个类从哪个jar包加载的?为什么会报各种类相关的Exception 。
(2)更改的代码为什么没执行?
(3)无法线上debug的问题
(4)线上某个数据有问题,但无法线上debug,线下无法重现 。
(5)是否有一个全局视角来查看系统的运行状况?
(6)有什么办法可以监控到JVM的实时运行状态?
3、基本使用(1)启动arthas-boot下载arthas-boot.jar,再用java -jar启动
wget https://alibaba.github.io/arthas/arthas-boot.jarjava -jar arthas-boot.jar 

推荐一个生产环境问题排查利器

文章插图
 
-h:表示输出帮助信息
arthas-boot.jar是Arthas的启动程序,启动后,会列出所有的java进程 。
推荐一个生产环境问题排查利器

文章插图
 
如果想跟进某个java进程,只需要输入对应的序号即可,Arthas会attach到目标进程上,并输出日志 。
推荐一个生产环境问题排查利器

文章插图
 
(2)查看dashboard输入dashboard,会展示当前进程的信息
(3)通过sysenv命令获取进程的Main class$ sysenv | grep MAIN JAVA_MAIN_CLASS_71560              demo.MathGame(4)通过jad来反编译某个类jad 类的全限定名(5)watch通过watch命令来查看某个类的某个方法的返回值
watch 类的全限定名 方法名 returnObj例如:
watch demo.MathGame primeFactors returnObj4、进阶使用基础命令
  • 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的环境变量
  • New!getstatic——查看类的静态属性
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——方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测
optionsoptions——查看或设置Arthas全局开关
管道Arthas支持使用管道对上述命令的结果进行进一步的处理,如sm org.Apache.log4j.Logger | grep


推荐阅读