栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

线上问题排查神器 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 用来监视一个时间段中指定方法的执行次数,成功次数,失败次数,耗时等这些信息

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/850613.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号