Arthas监控方法内部调用路径,并输出方法路径上的每个节点上耗时

在系统没有监控平台,或者监控平台,如PinPoint故障时,想要监控某个方法耗时可以借助Arthas

  • 解压 并启动

安装包下载完成后,进行解压,然后进入arthas bin目录(我这是Windows系统演示)

启动时,确保已经安装了JDK,然后使用java -jar命令启动arthas

启动成功后,会列出进程;选择要进入的进程标号对应的数字,如[1];直接输入 1,回车

  • 使用Trace命令 监控目标方法
html 复制代码
# Trace命令行
# 监控 ArtemisDoorServiceImpl实现类中的getDoorControlPointList方法
trace -E com.framework.service.impl.ArtemisDoorServiceImpl getDoorControlPointList

# 查看多个类多个方法的执行轨迹,用"|"分隔,两边不能有空格
trace -E com.framework.service.impl.ArtemisDoorServiceImpl|com.framework.service.impl.ArtemisDoor2ServiceImpl getDoorControlPointList|getDoorControlPointList2

其中,前面是类的Reference路径,后面跟方法名

除了Trace命令以外还可以使用monitor、watch命令对方法进行监控

monitor---方法执行监控

watch---方法执行数据观测

trace---方法内部调用路径,并输出方法路径上的每个节点上耗时(调用链路及耗时)

【请注意】,这些命令,都通过字节码增强技术来实现的,会在指定类的方法中插入一些切面来实现数据统计和观测,因此在线上、预发使用时,请尽量明确需要观测的类、方法以及条件,诊断结束要执行 stop 或将增强过的类执行 reset 命令。

  • Postman请求响应的接口,可以看到控制台打印出方法的耗时

查看方法执行入参

html 复制代码
$ watch com.framework.service.impl.ArtemisDoorController hello params

查看方法执行的返回值

html 复制代码
$ watch com.framework.service.impl.ArtemisDoorController hello returnObj
相关推荐
丹牛Daniel41 分钟前
Java解决HV000183: Unable to initialize ‘javax.el.ExpressionFactory‘
java·开发语言·spring boot·tomcat·intellij-idea·个人开发
消失的旧时光-19431 小时前
智能指针(三):实现篇 —— shared_ptr 的内部设计与引用计数机制
java·c++·c·shared_ptr
芒克芒克1 小时前
深入浅出CopyOnWriteArrayList
java
wuqingshun3141591 小时前
说一下java的反射机制
java·开发语言·jvm
A懿轩A1 小时前
【Java 基础编程】Java 异常处理保姆级教程:try-catch-finally、throw/throws、自定义异常
java·开发语言·python
极客先躯1 小时前
高级java每日一道面试题-2025年7月14日-基础篇[LangChain4j]-如何集成开源模型(如 Llama、Mistral)?需要什么基础设施?
java·langchain·存储·计算资源·模型服务框架·网络 / 协议·java 依赖
黎雁·泠崖2 小时前
Java 包装类:基本类型与引用类型的桥梁详解
java·开发语言
盖头盖3 小时前
【Java反序列化基础】
java
极客先躯3 小时前
高级java每日一道面试题-2025年7月15日-基础篇[LangChain4j]-如何集成国产大模型(如通义千问、文心一言、智谱 AI)?
java·人工智能·langchain·文心一言·异常处理·密钥管理·参数调优
追随者永远是胜利者3 小时前
(LeetCode-Hot100)226. 翻转二叉树
java·算法·leetcode·职场和发展·go