这篇文章主要为大家介绍了arthas jprofiler做复杂链路的调用分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
背景
Arthas是阿里巴巴开源的应用诊断利器,提供了profiler命令,可以生成热点火焰图。通过采样录制调用链路来做性能分析,极大提升了线上排查性能问题的效率。
但是有一个问题,当async-profiler全量采样导出的svg文件太大时,想要找到关键的调用点,就非常困难。
比如下图:
没有办法做聚合或过滤,这方面本地的profiler工具比如jprofiler、yourkits就方便很多,有没有办法将两者结合起来呢?
经过分析发现,async-profiler支持jfr (Java Flight Recorder)格式输出,jprofiler也支持打开jfr快照,成了!具体操作步骤如下:
1. arthas采样生成jfr文件
启动arthas之后,执行以下采样命令:
profiler start -f /home/admin/yourAppName/target/arthas-output/%t.jfr -d 180
%t 表示当前时间,-d 后面是采样秒数
更多参数参见:
https://arthas.aliyun.com/doc/profiler.html
https://github.com/jvm-profiling-tools/async-profiler/blob/v1.6/src/arguments.cpp
2. 下载jfr到本地
可以用oss倒腾,或者szrz等其他途径倒腾到本地。
3. jprofiler分析
在做性能分析时我们常常想要找出:是谁在调用我,是谁调用我最多。下面举例介绍怎么做的。
3.1 打开快照
使用jprofiler打开jfr文件,选择Open a snapshot, 打开之后选择CPU views
3.2 反向分析
View -> Find 查找要分析的类和方法,然后选择 Analyze -> Calculate Backtraces to Selected Method
3.3 分析结果
修改Summation mode 为Total times,即可看到这个方法被哪些上游调用到,调用量和占比
总结
- 通过Arthas profiler命令生成
jfr
文件; - 在本地通过
jprofiler
来分析jfr
文件,定位谁在调用我; - 运用之妙,存乎一心。工具的互相结合,可以产生奇妙的化学反应。
以上就是arthas jprofiler做复杂链路的调用分析的详细内容,更多关于arthas jprofiler复杂链路调用的资料请关注编程学习网其它相关文章!
本文标题为:arthas jprofiler做复杂链路的调用分析


基础教程推荐
- 用javascript制作qq注册动态页面 2023-12-16
- SpringBoot嵌入式Web容器原理与使用介绍 2023-06-17
- jsp hibernate的分页代码第3/3页 2024-01-11
- 详解http请求中的Content-Type 2023-07-31
- 关于@MapperScan包扫描的坑及解决 2023-04-16
- springboot中request和response的加解密实现代码 2022-12-08
- Spring MVC数据绑定方式 2023-06-30
- java 解决Eclipse挂掉问题的方法 2024-01-10
- SpringBoot 2.5.5整合轻量级的分布式日志标记追踪神器TLog的详细过程 2023-06-17
- JSP servlet实现文件上传下载和删除 2023-07-30