1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
use ore::{
metric,
metrics::{raw::HistogramVec, MetricsRegistry, UIntCounter},
};
#[derive(Clone, Debug)]
pub struct Metrics {
pub command_durations: HistogramVec,
pub bytes_sent: UIntCounter,
pub rows_returned: UIntCounter,
pub query_count: UIntCounter,
}
impl Metrics {
pub fn register_into(registry: &MetricsRegistry) -> Metrics {
Metrics {
command_durations: registry.register(metric!(
name: "mz_command_durations",
help: "how long individual commands took",
var_labels: ["command", "status"],
)),
query_count: registry.register(metric!(
name: "mz_query_count",
help: "total number of queries executed",
)),
rows_returned: registry.register(metric!(
name: "mz_pg_sent_rows",
help: "total number of rows sent to clients from pgwire",
)),
bytes_sent: registry.register(metric!(
name: "mz_pg_sent_bytes",
help: "total number of bytes sent to clients from pgwire",
)),
}
}
}