大厂面试真题-Arthas有哪些常用的命令

Arthas是Alibaba开源的一款Java诊断工具,它可以在不重启JVM的情况下,动态地查看JVM运行状态、类加载情况、内存使用情况、线程执行情况等,帮助开发者轻松排查线上问题。以下是Arthas排查线上问题时常用的命令:

  1. dashboard:进入仪表盘,可以监控线程、内存状态、GC(垃圾回收)等信息,是查看JVM整体运行情况的快速入口。

  2. thread:用于查看线程情况。可以打印出所有线程的信息,或者打印出最忙的前N个线程。此外,还可以通过特定参数找出阻塞其他线程的线程,以及查看线程的堆栈信息等。

    • 打印全部线程:thread
    • 打印最忙的前10条线程:thread -n 10
    • 找出阻塞其他线程的线程:thread -b
  3. sc(search-class) :查看已经加载的类。例如,sc com.XXX.sgw.controller.* 可以查看指定包下的所有类。

  4. trace :追踪方法堆栈调用时间,输出各个节点的耗时。主要用于响应慢的时候,帮助开发者找到性能瓶颈。例如,trace com.XXX.controller.api.ServiceGatewayV1Controller list 可以追踪指定方法的调用链路和耗时。

  5. watch :查看程序调用的入参和出参,类似于debug功能。例如,watch com.XXX.controller.api.ServiceGatewayV1Controller list "{params[0],params[1],returnObj}" 可以观察指定方法的参数和返回值。

  6. tt(time-tunnel) :记录方法执行数据的时空隧道,可以回溯方法的执行情况。例如,tt -t com.XXX.vo.PageVo getPageSize 可以记录指定方法的执行情况,然后通过tt -i <record-id> -w "target.getPageSize()"来回溯方法的执行结果。

  7. stack :查看方法被调用的路径。例如,stack com.XXX.service.impl.PostgresqlServiceImpl customQuery 可以查看指定方法的调用路径。

  8. jad :反编译线上代码,查看源代码的详细信息。例如,jad --source-only com.yingzi.data.sgw.controller.api.ServiceGatewayV1Controller 可以反编译指定类并查看其源代码。

  9. monitor :统计方法的调用情况,包括调用次数、成功次数、失败次数和平均响应时间等。例如,monitor -c 3 com.yingzi.data.sgw.controller.api.ServiceGatewayV1Controller list 可以以3秒为一个时间窗口,统计指定方法的调用情况。

  10. profiler :生成火焰图,帮助分析CPU占用情况。例如,profiler start 可以启动CPU火焰图的采集,profiler stop 可以停止采集并生成火焰图文件。火焰图的X轴代表采样总量(所有执行的耗时CPU的方法),Y轴代表方法的调用栈深度,每一层都是一个方法。通过火焰图,开发者可以直观地看到哪些方法占用了大量的CPU资源。

此外,还有一些其他常用的命令,如cls(清空面板)、exit(退出当前会话)、stop(关闭Arthas)等。这些命令可以帮助开发者更高效地排查线上问题,提高问题解决的效率。

相关推荐
LCG元27 分钟前
【面试问题】JIT 是什么?和 JVM 什么关系?
面试·职场和发展
xlsw_1 小时前
java全栈day20--Web后端实战(Mybatis基础2)
java·开发语言·mybatis
神仙别闹2 小时前
基于java的改良版超级玛丽小游戏
java
黄油饼卷咖喱鸡就味增汤拌孜然羊肉炒饭2 小时前
SpringBoot如何实现缓存预热?
java·spring boot·spring·缓存·程序员
暮湫3 小时前
泛型(2)
java
超爱吃士力架3 小时前
邀请逻辑
java·linux·后端
南宫生3 小时前
力扣-图论-17【算法学习day.67】
java·学习·算法·leetcode·图论
转码的小石3 小时前
12/21java基础
java
李小白663 小时前
Spring MVC(上)
java·spring·mvc
GoodStudyAndDayDayUp3 小时前
IDEA能够从mapper跳转到xml的插件
xml·java·intellij-idea