Skip to content

Commit

Permalink
[fix]: Report correct view change index for current round
Browse files Browse the repository at this point in the history
Signed-off-by: Shanin Roman <[email protected]>
  • Loading branch information
Erigara committed Apr 19, 2024
1 parent 4748a33 commit fa03b1a
Show file tree
Hide file tree
Showing 5 changed files with 36 additions and 15 deletions.
7 changes: 5 additions & 2 deletions cli/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ use iroha_core::{
try_read_snapshot, SnapshotMaker, SnapshotMakerHandle, TryReadError as TryReadSnapshotError,
},
state::{State, StateReadOnly, World},
sumeragi::{GenesisWithPubKey, SumeragiHandle, SumeragiStartArgs},
sumeragi::{GenesisWithPubKey, SumeragiHandle, SumeragiMetrics, SumeragiStartArgs},
IrohaNetwork,
};
use iroha_data_model::prelude::*;
Expand Down Expand Up @@ -278,7 +278,10 @@ impl Iroha {
public_key: config.genesis.public_key().clone(),
},
block_count,
dropped_messages: metrics_reporter.metrics().dropped_messages.clone(),
sumeragi_metrics: SumeragiMetrics {
dropped_messages: metrics_reporter.metrics().dropped_messages.clone(),
view_changes: metrics_reporter.metrics().view_changes.clone(),
},
};
// Starting Sumeragi requires no async context enabled
let sumeragi = tokio::task::spawn_blocking(move || SumeragiHandle::start(start_args))
Expand Down
4 changes: 0 additions & 4 deletions core/src/metrics.rs
Original file line number Diff line number Diff line change
Expand Up @@ -139,10 +139,6 @@ impl MetricsReporter {
.set(domain.accounts.len() as u64);
}

self.metrics
.view_changes
.set(state_view.latest_block_view_change_index());

self.metrics.queue_size.set(self.queue.tx_len() as u64);

Ok(())
Expand Down
4 changes: 4 additions & 0 deletions core/src/sumeragi/main_loop.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,8 @@ pub struct Sumeragi {
/// sumeragi is more dependent on the code that is internal to the
/// subsystem.
pub transaction_cache: Vec<AcceptedTransaction>,
/// Metrics for reporting number of view changes in current round
pub view_changes_metric: iroha_telemetry::metrics::ViewChangesGauge,
}

#[allow(clippy::missing_fields_in_debug)]
Expand Down Expand Up @@ -919,6 +921,7 @@ pub(crate) fn run(
&mut last_view_change_time,
&mut view_change_time,
);
sumeragi.view_changes_metric.set(old_view_change_index);

if let Some(message) = {
let (msg, sleep) =
Expand Down Expand Up @@ -999,6 +1002,7 @@ pub(crate) fn run(
&mut last_view_change_time,
&mut view_change_time,
);
sumeragi.view_changes_metric.set(old_view_change_index);

sumeragi.process_message_independent(
&state,
Expand Down
25 changes: 19 additions & 6 deletions core/src/sumeragi/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ use crate::{kura::Kura, prelude::*, queue::Queue, EventsSender, IrohaNetwork, Ne
#[derive(Clone)]
pub struct SumeragiHandle {
/// Counter for amount of dropped messages by sumeragi
dropped_messages: iroha_telemetry::metrics::IntCounter,
dropped_messages_metric: iroha_telemetry::metrics::DroppedMessagesCounter,
_thread_handle: Arc<ThreadHandler>,
// Should be dropped after `_thread_handle` to prevent sumeargi thread from panicking
control_message_sender: mpsc::SyncSender<ControlFlowMessage>,
Expand All @@ -45,7 +45,7 @@ impl SumeragiHandle {
/// Deposit a sumeragi control flow network message.
pub fn incoming_control_flow_message(&self, msg: ControlFlowMessage) {
if let Err(error) = self.control_message_sender.try_send(msg) {
self.dropped_messages.inc();
self.dropped_messages_metric.inc();
error!(
?error,
"This peer is faulty. \
Expand All @@ -57,7 +57,7 @@ impl SumeragiHandle {
/// Deposit a sumeragi network message.
pub fn incoming_block_message(&self, msg: BlockMessage) {
if let Err(error) = self.message_sender.try_send(msg) {
self.dropped_messages.inc();
self.dropped_messages_metric.inc();
error!(
?error,
"This peer is faulty. \
Expand Down Expand Up @@ -128,7 +128,11 @@ impl SumeragiHandle {
network,
genesis_network,
block_count: BlockCount(block_count),
dropped_messages,
sumeragi_metrics:
SumeragiMetrics {
view_changes,
dropped_messages,
},
}: SumeragiStartArgs,
) -> SumeragiHandle {
let (control_message_sender, control_message_receiver) = mpsc::sync_channel(100);
Expand Down Expand Up @@ -204,6 +208,7 @@ impl SumeragiHandle {
debug_force_soft_fork,
current_topology,
transaction_cache: Vec::new(),
view_changes_metric: view_changes,
};

// Oneshot channel to allow forcefully stopping the thread.
Expand All @@ -227,7 +232,7 @@ impl SumeragiHandle {

let thread_handle = ThreadHandler::new(Box::new(shutdown), thread_handle);
SumeragiHandle {
dropped_messages,
dropped_messages_metric: dropped_messages,
control_message_sender,
message_sender,
_thread_handle: Arc::new(thread_handle),
Expand Down Expand Up @@ -295,7 +300,15 @@ pub struct SumeragiStartArgs {
pub network: IrohaNetwork,
pub genesis_network: GenesisWithPubKey,
pub block_count: BlockCount,
pub dropped_messages: iroha_telemetry::metrics::IntCounter,
pub sumeragi_metrics: SumeragiMetrics,
}

/// Relevant sumeragi metrics
pub struct SumeragiMetrics {
/// Number of view changes in current round
pub view_changes: iroha_telemetry::metrics::ViewChangesGauge,
/// Amount of dropped messages by sumeragi
pub dropped_messages: iroha_telemetry::metrics::DroppedMessagesCounter,
}

/// Optional genesis paired with genesis public key for verification
Expand Down
11 changes: 8 additions & 3 deletions telemetry/src/metrics.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,17 @@
use std::{ops::Deref, time::Duration};

use parity_scale_codec::{Compact, Decode, Encode};
pub use prometheus::{
use prometheus::{
core::{AtomicU64, GenericGauge, GenericGaugeVec},
Encoder, Histogram, HistogramOpts, HistogramVec, IntCounter, IntCounterVec, Opts, Registry,
};
use serde::{Deserialize, Serialize};

/// Type for reporting amount of dropped messages for sumeragi
pub type DroppedMessagesCounter = IntCounter;
/// Type for reporting view change index of current round
pub type ViewChangesGauge = GenericGauge<AtomicU64>;

/// Thin wrapper around duration that `impl`s [`Default`]
#[derive(Debug, Clone, Copy, Serialize, Deserialize)]
pub struct Uptime(pub Duration);
Expand Down Expand Up @@ -102,11 +107,11 @@ pub struct Metrics {
/// Query handle time Histogram
pub isi_times: HistogramVec,
/// Number of view changes in the current round
pub view_changes: GenericGauge<AtomicU64>,
pub view_changes: ViewChangesGauge,
/// Number of transactions in the queue
pub queue_size: GenericGauge<AtomicU64>,
/// Number of sumeragi dropped messages
pub dropped_messages: IntCounter,
pub dropped_messages: DroppedMessagesCounter,
/// Internal use only. Needed for generating the response.
registry: Registry,
}
Expand Down

0 comments on commit fa03b1a

Please sign in to comment.