JVM Profiler 整体架构

开篇


整个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虚拟机

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容