1 个不稳定版本
0.1.0 | 2021 年 10 月 13 日 |
---|
#58 在 #observability
51KB
1K SLoC
Metriki
Metriki 是从 Dropwizard Metrics 转移过来的 Rust 库。
与 Dropwizard Metrics 类似,Metriki 在客户端聚合度量并输出有限的数据。
快速开始
// create a timer to track the execution rate and latency of this function
// to use macros you will need to turn on `macros` feature of metriki_core
#[timed]
fn your_function() {
// a function metered by a timer for its rate and latency
}
use metriki_core::global::global_registry;
use metriki_influxdb_reporter::InfluxDbReporterBuilder;
// by default, the timer is registered in this global_registry()
let registry = global_registry();
// start a reporter to send data into influxdb
InfluxDbReporterBuilder::default()
.registry(registry.clone())
.build()
.start();
组件
概念
度量
- Counter: 可增加和减少的值。
- Meter: 测量事件速率。
- Histogram: 记录随时间变化的数据分布。
- Timer: 计数器和直方图的组合。
- Gauge: 当查询时提供值的函数。
MetricsRegistry
所有度量的入口点和持有者。
MetricsSet
一个要实现的特质,以便将动态度量添加到注册表中。当报告器和导出器从注册表中提取值时,集合中的度量会被拉入注册表。
报告器
一个定期报告度量数据的组件。通常用于具有推送模式的接收器。
导出器
一个将度量数据暴露给外部查询器的组件。通常用于基于拉取的数据接收器。
许可证
MIT/Apache-2.0
依赖项
~3.5–9.5MB
~92K SLoC