From 56b187b944ced0afff7b866599065838b9df5c40 Mon Sep 17 00:00:00 2001 From: Philippe McLean Date: Wed, 22 May 2024 12:53:22 -0700 Subject: [PATCH] Add main loop prometheus gauge for liveness monitoring --- src/bin/electrs.rs | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/src/bin/electrs.rs b/src/bin/electrs.rs index 950641d50..fb25e68a8 100644 --- a/src/bin/electrs.rs +++ b/src/bin/electrs.rs @@ -22,6 +22,7 @@ use electrs::{ #[cfg(feature = "liquid")] use electrs::elements::AssetRegistry; +use electrs::metrics::MetricOpts; fn fetch_from(config: &Config, store: &Store) -> FetchFrom { let mut jsonrpc_import = config.jsonrpc_import; @@ -110,7 +111,15 @@ fn run_server(config: Arc) -> Result<()> { let rest_server = rest::start(Arc::clone(&config), Arc::clone(&query)); let electrum_server = ElectrumRPC::start(Arc::clone(&config), Arc::clone(&query), &metrics); + let main_loop_count = metrics.gauge(MetricOpts::new( + "electrs_main_loop_count", + "count of iterations of electrs main loop each 5 seconds or after interrupts", + )); + loop { + + main_loop_count.inc(); + if let Err(err) = signal.wait(Duration::from_secs(5), true) { info!("stopping server: {}", err); rest_server.stop();