您现在的位置是:首页 > 文章详情

JVM Profiler 整体架构

日期:2018-09-03点击:380

开篇

img_001c27e1ca54627cd8d9d9a806530ace.png

整个JVM Profiler的组件类似于上图,抽象出来主要分为:
Class File Transformer:负责转换被监控方法的字节码,在前后增加耗时统计。
Profiler:负责数据的采集,各种指标的采集器。
Reporter:数据上报方法,支持kafka,Console,Redis,File等多种方式。


组件介绍

Profiler介绍

  • CpuAndMemoryProfiler:负责采集cpu和内存指标的Profiler。
  • IOProfiler:负责采集机器IO指标的Profiler。
  • MethodArgumentProfiler:负责采集被监控方法参数的Profiler。
  • MethodDurationProfiler:负责采集被监控方法耗时的Profiler。
  • ProcessInfoProfiler:负责采集Process相关信息的Profiler。
  • StacktraceCollectorProfiler:负责Stack相关信息的Profiler,细节还没弄清楚。
  • StacktraceReporterProfiler:负责Stack相关信息的Profiler,细节还没弄清楚。


Reporter介绍

  • ConsoleOutputReporter:采集数据输出到终端命令行。
  • FileOutputReporter:采集数据输出到文件。
  • KafkaOutputReporter:采集数据输出到kafka。
  • RedisOutputReporter:采集输出输出到redis。


Transformer介绍

  • Transformer用在采集被监控方法字节码前后增加耗时统计,主要是在方法执行前增加开始时间的统计,在方法执行后增加结束时间的统计,然后计算差值得到最终的耗时。


参考文章

Uber开源JVM Profiler,用以跟踪分布式Java虚拟机

原文链接:https://yq.aliyun.com/articles/666302
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章