线上问题排查神器 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表示对象展开的层数)
watch com.cecjx.business.service.impl.LicRequestServiceImpl dealData params,returnObj -x 3
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的简单使用的主要内容,如果未能解决你的问题,请参考以下文章
java生产环境调试问题排查神器arthas(阿里中台开源的)
Java 线上问题排查神器 Arthas 快速上手与原理浅谈