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

2 篇文章 0 订阅

环境

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 查看当前线程信息,查看线程的堆栈
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 用来监视一个时间段中指定方法的执行次数,成功次数,失败次数,耗时等这些信息

在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值