开篇
整个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用在采集被监控方法字节码前后增加耗时统计,主要是在方法执行前增加开始时间的统计,在方法执行后增加结束时间的统计,然后计算差值得到最终的耗时。