TypechoJoeTheme

王子博客

用户名
密码
用户名
邮箱

利用Arthas排查接口慢的情况

王子博主
2020-09-01
/
0 评论
/
229 阅读
/
563 个字
/
百度已收录
09/01
本文最后更新于2022年08月27日,已超过613天没有更新。如果文章内容或图片资源失效,请留言反馈,我会及时处理,谢谢!

工作中遇到这么一个

所以就准备去排查接口的调用情况。经过了解发现Arthas可以帮助我排查接口缓慢的情况;

Arthas地址:https://github.com/alibaba/arthas/blob/master/README_CN.md#arthas

Arthas 是Alibaba开源的Java诊断工具,深受开发者喜爱。
当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:

这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
是否有一个全局视角来查看系统的运行状况?
有什么办法可以监控到JVM的实时运行状态?
怎么快速定位应用的热点,生成火焰图?
Arthas支持JDK 6+,支持Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。

快速开始
使用arthas-boot(推荐)
下载arthas-boot.jar,然后用java -jar的方式启动:

curl -O https://arthas.aliyun.com/arthas-boot.jar
java -jar arthas-boot.jar

打印帮助信息:

java -jar arthas-boot.jar -h

如果下载速度比较慢,可以使用aliyun的镜像:java -jar arthas-boot.jar --repo-mirror aliyun --use-http
使用as.sh
Arthas 支持在 Linux/Unix/Mac 等平台上一键安装,请复制以下内容,并粘贴到命令行中,敲 回车 执行即可:

curl -L https://arthas.aliyun.com/install.sh | sh

上述命令会下载启动脚本文件 as.sh 到当前目录,你可以放在任何地方或将其加入到 $PATH 中。

直接在shell下面执行./as.sh,就会进入交互界面。

也可以执行./as.sh -h来获取更多参数信息。

具体使用
安装之后执行

./as.sh

会列出所有检测到的进程

选择你要跟踪的服务,比如我要跟踪leimingtech-search-api这个服务。那么输入9然后回车

然后就是启动成功

然后就是使用trace命令
trace命令的使用文档:https://arthas.aliyun.com/doc/trace

命令

trace  类全称  + 空格  + 方法名

在我的项目中就是这样的:

trace com.leimingtech.front.modules.service.impl.GoodsSearchServiceImpl collectBillsReduceGoods

运行结果:

可以看到箭头的地方就是这次接口调用中耗时比较久的方法。最后在去定位这个方法的调用情况;

Arthas接口慢
朗读
赞(0)
版权属于:

王子博客

本文链接:

http://120.78.163.174/index.php/archives/5/(转载时请注明本文出处及文章链接)

评论 (0)