mirror of
https://github.com/0glabs/0g-storage-node.git
synced 2024-12-24 07:15:17 +00:00
Supports generic metrics for rpc (#298)
Some checks failed
abi-consistent-check / build-and-compare (push) Has been cancelled
code-coverage / unittest-cov (push) Has been cancelled
rust / check (push) Has been cancelled
rust / test (push) Has been cancelled
rust / lints (push) Has been cancelled
functional-test / test (push) Has been cancelled
Some checks failed
abi-consistent-check / build-and-compare (push) Has been cancelled
code-coverage / unittest-cov (push) Has been cancelled
rust / check (push) Has been cancelled
rust / test (push) Has been cancelled
rust / lints (push) Has been cancelled
functional-test / test (push) Has been cancelled
This commit is contained in:
parent
affa14e8b7
commit
349e13e7fc
1
Cargo.lock
generated
1
Cargo.lock
generated
@ -6594,6 +6594,7 @@ dependencies = [
|
|||||||
"metrics",
|
"metrics",
|
||||||
"miner",
|
"miner",
|
||||||
"network",
|
"network",
|
||||||
|
"parking_lot 0.12.3",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"shared_types",
|
"shared_types",
|
||||||
|
@ -27,3 +27,4 @@ merkle_light = { path = "../../common/merkle_light" }
|
|||||||
merkle_tree = { path = "../../common/merkle_tree"}
|
merkle_tree = { path = "../../common/merkle_tree"}
|
||||||
futures-channel = "^0.3"
|
futures-channel = "^0.3"
|
||||||
metrics = { workspace = true }
|
metrics = { workspace = true }
|
||||||
|
parking_lot = "0.12.3"
|
||||||
|
@ -6,6 +6,7 @@ extern crate miner as zgs_miner;
|
|||||||
mod admin;
|
mod admin;
|
||||||
mod config;
|
mod config;
|
||||||
mod error;
|
mod error;
|
||||||
|
mod middleware;
|
||||||
mod miner;
|
mod miner;
|
||||||
pub mod types;
|
pub mod types;
|
||||||
mod zgs;
|
mod zgs;
|
||||||
@ -77,8 +78,10 @@ pub async fn run_server(
|
|||||||
Ok(handles)
|
Ok(handles)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn server_builder(ctx: Context) -> HttpServerBuilder {
|
fn server_builder(ctx: Context) -> HttpServerBuilder<middleware::Metrics> {
|
||||||
HttpServerBuilder::default().max_request_body_size(ctx.config.max_request_body_size)
|
HttpServerBuilder::default()
|
||||||
|
.max_request_body_size(ctx.config.max_request_body_size)
|
||||||
|
.set_middleware(middleware::Metrics::default())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Run a single RPC server for all namespace RPCs.
|
/// Run a single RPC server for all namespace RPCs.
|
||||||
|
50
node/rpc/src/middleware.rs
Normal file
50
node/rpc/src/middleware.rs
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
use std::{collections::HashMap, sync::Arc, time::Instant};
|
||||||
|
|
||||||
|
use jsonrpsee::core::middleware::Middleware;
|
||||||
|
use metrics::{register_meter_with_group, Histogram, Meter, Sample};
|
||||||
|
use parking_lot::RwLock;
|
||||||
|
|
||||||
|
struct RpcMetric {
|
||||||
|
qps: Arc<dyn Meter>,
|
||||||
|
latency: Arc<dyn Histogram>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl RpcMetric {
|
||||||
|
fn new(method_name: &String) -> Self {
|
||||||
|
let group = format!("rpc_{}", method_name);
|
||||||
|
|
||||||
|
Self {
|
||||||
|
qps: register_meter_with_group(group.as_str(), "qps"),
|
||||||
|
latency: Sample::ExpDecay(0.015).register_with_group(group.as_str(), "latency", 1024),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Clone, Default)]
|
||||||
|
pub struct Metrics {
|
||||||
|
metrics_by_method: Arc<RwLock<HashMap<String, RpcMetric>>>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Middleware for Metrics {
|
||||||
|
type Instant = Instant;
|
||||||
|
|
||||||
|
fn on_request(&self) -> Self::Instant {
|
||||||
|
Instant::now()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn on_call(&self, name: &str) {
|
||||||
|
let mut metrics_by_method = self.metrics_by_method.write();
|
||||||
|
let entry = metrics_by_method
|
||||||
|
.entry(name.to_string())
|
||||||
|
.or_insert_with_key(RpcMetric::new);
|
||||||
|
entry.qps.mark(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn on_result(&self, name: &str, _success: bool, started_at: Self::Instant) {
|
||||||
|
let mut metrics_by_method = self.metrics_by_method.write();
|
||||||
|
let entry = metrics_by_method
|
||||||
|
.entry(name.to_string())
|
||||||
|
.or_insert_with_key(RpcMetric::new);
|
||||||
|
entry.latency.update_since(started_at);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user