From 8df6db161d2ea6916f2b0c771b646fac1ffb3922 Mon Sep 17 00:00:00 2001 From: Matan Markind Date: Mon, 12 Aug 2024 11:59:45 +0300 Subject: [PATCH] feat(consensus): redefine consensus height metric to working height This will be more useful than stating the most recent decision when we are stuck on block 0. Also moved out of Context::decision due to sync --- crates/papyrus_common/src/metrics.rs | 2 +- crates/sequencing/papyrus_consensus/run_consensus.py | 2 +- crates/sequencing/papyrus_consensus/src/manager.rs | 3 +++ .../papyrus_consensus/src/papyrus_consensus_context.rs | 2 -- 4 files changed, 5 insertions(+), 4 deletions(-) diff --git a/crates/papyrus_common/src/metrics.rs b/crates/papyrus_common/src/metrics.rs index c618ab06785..b06f42fec8a 100644 --- a/crates/papyrus_common/src/metrics.rs +++ b/crates/papyrus_common/src/metrics.rs @@ -38,5 +38,5 @@ pub const PAPYRUS_NUM_ACTIVE_OUTBOUND_SESSIONS: &str = "papyrus_num_active_outbo /// Global variable set by the main config to enable collecting profiling metrics. pub static COLLECT_PROFILING_METRICS: OnceLock = OnceLock::new(); -/// The height most recently decided by consensus. +/// The height consensus is currently working on. pub const PAPYRUS_CONSENSUS_HEIGHT: &str = "papyrus_consensus_height"; diff --git a/crates/sequencing/papyrus_consensus/run_consensus.py b/crates/sequencing/papyrus_consensus/run_consensus.py index bd69c8495b1..1b19ab3cde9 100644 --- a/crates/sequencing/papyrus_consensus/run_consensus.py +++ b/crates/sequencing/papyrus_consensus/run_consensus.py @@ -35,7 +35,7 @@ def get_height(self): port = self.monitoring_gateway_server_port command = f"curl -s -X GET http://localhost:{port}/monitoring/metrics | grep -oP 'papyrus_consensus_height \\K\\d+'" result = subprocess.run(command, shell=True, capture_output=True, text=True) - # returns the latest decided height, or None if node isn't ready or no height reached. + # returns the latest decided height, or None if consensus has not yet started. return int(result.stdout) if result.stdout else None def check_height(self): diff --git a/crates/sequencing/papyrus_consensus/src/manager.rs b/crates/sequencing/papyrus_consensus/src/manager.rs index 8a8324a2790..9defc700228 100644 --- a/crates/sequencing/papyrus_consensus/src/manager.rs +++ b/crates/sequencing/papyrus_consensus/src/manager.rs @@ -9,6 +9,7 @@ use std::time::Duration; use futures::channel::{mpsc, oneshot}; use futures::{Stream, StreamExt}; +use papyrus_common::metrics::PAPYRUS_CONSENSUS_HEIGHT; use papyrus_network::network_manager::ReportSender; use papyrus_protobuf::consensus::{ConsensusMessage, Proposal}; use papyrus_protobuf::converters::ProtobufConversionError; @@ -50,6 +51,8 @@ where let mut current_height = start_height; let mut manager = MultiHeightManager::new(); loop { + metrics::gauge!(PAPYRUS_CONSENSUS_HEIGHT, current_height.0 as f64); + let run_height = manager.run_height(&mut context, current_height, validator_id, &mut network_receiver); diff --git a/crates/sequencing/papyrus_consensus/src/papyrus_consensus_context.rs b/crates/sequencing/papyrus_consensus/src/papyrus_consensus_context.rs index 6f9d8f737e5..3af428ce821 100644 --- a/crates/sequencing/papyrus_consensus/src/papyrus_consensus_context.rs +++ b/crates/sequencing/papyrus_consensus/src/papyrus_consensus_context.rs @@ -9,7 +9,6 @@ use async_trait::async_trait; use futures::channel::{mpsc, oneshot}; use futures::sink::SinkExt; use futures::StreamExt; -use papyrus_common::metrics::PAPYRUS_CONSENSUS_HEIGHT; use papyrus_network::network_manager::BroadcastSubscriberSender; use papyrus_protobuf::consensus::{ConsensusMessage, Proposal, Vote}; use papyrus_storage::body::BodyStorageReader; @@ -237,7 +236,6 @@ impl ConsensusContext for PapyrusConsensusContext { "Finished consensus for height: {height}. Agreed on block with id: {:x}", block.id().0 ); - metrics::gauge!(PAPYRUS_CONSENSUS_HEIGHT, height as f64); Ok(()) } }