大厂面试真题-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)等。这些命令可以帮助开发者更高效地排查线上问题,提高问题解决的效率。

相关推荐
Theodore_10222 小时前
4 设计模式原则之接口隔离原则
java·开发语言·设计模式·java-ee·接口隔离原则·javaee
冰帝海岸3 小时前
01-spring security认证笔记
java·笔记·spring
世间万物皆对象3 小时前
Spring Boot核心概念:日志管理
java·spring boot·单元测试
没书读了4 小时前
ssm框架-spring-spring声明式事务
java·数据库·spring
小二·4 小时前
java基础面试题笔记(基础篇)
java·笔记·python
开心工作室_kaic4 小时前
ssm161基于web的资源共享平台的共享与开发+jsp(论文+源码)_kaic
java·开发语言·前端
懒洋洋大魔王4 小时前
RocketMQ的使⽤
java·rocketmq·java-rocketmq
武子康4 小时前
Java-06 深入浅出 MyBatis - 一对一模型 SqlMapConfig 与 Mapper 详细讲解测试
java·开发语言·数据仓库·sql·mybatis·springboot·springcloud
转世成为计算机大神5 小时前
易考八股文之Java中的设计模式?
java·开发语言·设计模式
qq_327342735 小时前
Java实现离线身份证号码OCR识别
java·开发语言