线上问题排查神器 Arthas的简单使用

Posted scanner小霸王

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了线上问题排查神器 Arthas的简单使用相关的知识,希望对你有一定的参考价值。

环境

jdk6以上,支持linux/Mac/windows

指令

1)java -jar arthas-boot.jar,
接着再指定黏附的线程即可
(启动的时候,如果端口被占用,可以指定其他端口
java -jar arthas-boot.jar --telnet-port 9998 --http-port -1)


2)dashboard 仪表板
输入dashboard,按回车/enter,会展示当前进程的信息,按ctrl+c可以中断执行。

第一部分是显示JVM中运行的所有线程:所在线程组,优先级,线程的状态,CPU的占用率,是否是后台进程等
第二部分显示的JVM内存的使用情况
第三部分是操作系统的一些信息和Java版本号

3)thread 查看当前线程信息,查看线程的堆栈


4)通过jad来反编译Class

5)、watch 来查看返回值
(-x表示对象展开的层数)


6)trace类似watch
trace com.cecjx.business.controller.LicRequestProvincialApproveController selectPage

7)退出arthas
如果只是退出当前的连接,可以用quit或者exit命令。
Attach到目标进程上的arthas还会继续运行,端口会保持开放,下次连接时可以直接连接上。
如果想完全退出arthas,可以执行stop命令。

8)cls清空当前屏幕区域

9)jvm 查看当前 JVM 的信息

10)sysenv 查看当前JVM的环境属性(System Environment Variables)


查看单个

11)getstatic 通过getstatic命令可以方便的查看类的静态属性

getstatic 类名 属性名
例如:

# 显示demo.MathGame类中静态属性random
getstatic demo.MathGame random

12)sm 命令只能看到由当前类所声明 (declaring) 的方法,父类则无法看到。
显示String类加载的方法
sm java.lang.String

显示String中的toString方法详细信息
sm -d java.lang.String toString


13)结合jad/mc命令使用
a) 使用jad反编译com.cecjx.business.controller.LicRequestProvincialApproveControlle输出到/opt/app/modules/LicRequestProvincialApproveController.java

jad --source-only  com.cecjx.business.controller.LicRequestProvincialApproveController > /opt/app/modules/LicRequestProvincialApproveController.java

b).按上面的代码编辑完毕以后,使用mc内存中对新的代码编译
mc /opt/app/modules/LicRequestController.java -d /opt/app/modules

c)使用redefine命令加载新的字节码
redefine /opt/app/modules/LicRequestController.class

14)#monitor -c 5
com.cecjx.business.controller.LicRequestProvincialApproveController selectPage

monitor 用来监视一个时间段中指定方法的执行次数,成功次数,失败次数,耗时等这些信息

以上是关于线上问题排查神器 Arthas的简单使用的主要内容,如果未能解决你的问题,请参考以下文章

线上问题排查神器 Arthas的简单使用

arthas排查线上问题真是太好用了!

java生产环境调试问题排查神器arthas(阿里中台开源的)

Java 线上问题排查神器 Arthas 快速上手与原理浅谈

一文带你快速了解 Java 线上问题快速诊断神器 Arthas

一文带你快速了解 Java 线上问题快速诊断神器 Arthas