JVM Profiler 整体架构

开篇

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值