5 个版本
0.2.0 | 2023年10月21日 |
---|---|
0.1.4 | 2021年8月6日 |
0.1.3 | 2021年4月19日 |
0.1.1 | 2021年2月21日 |
0.1.0 | 2021年2月12日 |
#487 在 调试
用于 4 个代码包
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()
.url("localhost:8086")
.username(String::from("influxdbuser"))
.password(String::from("yourpassword"))
.database("db")
.registry(registry.clone())
.build()
.unwrap()
.start();
组件
概念
指标
- 计数器:可以增加和减少的值。
- 度量器:测量事件的速率。
- 直方图:记录数据随时间分布。
- 计时器:度量器和直方图的组合。
- 仪表:当被查询时提供值的函数。
MetricsRegistry
所有指标的入口点和持有者。
MetricsSet
一个需要实现的特质,以便将动态指标添加到注册表中。每当报告器和导出器从注册表中提取值时,集合中的指标都会被拉入注册表。
Reporter
一个组件,用于定期报告指标数据。通常用于具有推送模式的 数据接收器。
Exporter
一个组件,用于向外部查询者公开指标数据。通常用于基于拉取的数据接收器。
许可证
MIT/Apache-2.0
依赖关系
~3–8.5MB
~77K SLoC