risingwave_compute/rpc/service/
exchange_metrics.rs1use std::sync::LazyLock;
16
17use prometheus::core::{AtomicU64, GenericCounterVec};
18use prometheus::{Registry, register_int_counter_vec_with_registry};
19use risingwave_common::monitor::GLOBAL_METRICS_REGISTRY;
20
21#[derive(Clone)]
22pub struct ExchangeServiceMetrics {
23 pub stream_fragment_exchange_bytes: GenericCounterVec<AtomicU64>,
24}
25
26pub static GLOBAL_EXCHANGE_SERVICE_METRICS: LazyLock<ExchangeServiceMetrics> =
27 LazyLock::new(|| ExchangeServiceMetrics::new(&GLOBAL_METRICS_REGISTRY));
28
29impl ExchangeServiceMetrics {
30 fn new(registry: &Registry) -> Self {
31 let stream_fragment_exchange_bytes = register_int_counter_vec_with_registry!(
32 "stream_exchange_frag_send_size",
33 "Total size of messages that have been send to downstream Fragment",
34 &["up_fragment_id", "down_fragment_id"],
35 registry
36 )
37 .unwrap();
38
39 Self {
40 stream_fragment_exchange_bytes,
41 }
42 }
43}