From afd766a617eeb0d9bbb70e284f716a06479dcd69 Mon Sep 17 00:00:00 2001 From: asolana <110843012+ksolana@users.noreply.github.com> Date: Mon, 4 Nov 2024 10:26:17 -0800 Subject: [PATCH] Report mean,min,max ConsumeWorkerMetrics::timing_metrics (#3321) * Report mean,min,max * Directly send the commit_count instead of computing the mean * Rename commit_count to num_batches_processed --- core/src/banking_stage/consume_worker.rs | 27 ++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/core/src/banking_stage/consume_worker.rs b/core/src/banking_stage/consume_worker.rs index e1533dfd4b1e98..c2dee98a3eba32 100644 --- a/core/src/banking_stage/consume_worker.rs +++ b/core/src/banking_stage/consume_worker.rs @@ -295,6 +295,12 @@ impl ConsumeWorkerMetrics { self.timing_metrics .collect_balances_us .fetch_add(*collect_balances_us, Ordering::Relaxed); + self.timing_metrics + .load_execute_us_min + .fetch_min(*load_execute_us, Ordering::Relaxed); + self.timing_metrics + .load_execute_us_max + .fetch_max(*load_execute_us, Ordering::Relaxed); self.timing_metrics .load_execute_us .fetch_add(*load_execute_us, Ordering::Relaxed); @@ -310,6 +316,9 @@ impl ConsumeWorkerMetrics { self.timing_metrics .find_and_send_votes_us .fetch_add(*find_and_send_votes_us, Ordering::Relaxed); + self.timing_metrics + .num_batches_processed + .fetch_add(1, Ordering::Relaxed); } fn update_on_error_counters( @@ -505,12 +514,15 @@ struct ConsumeWorkerTimingMetrics { cost_model_us: AtomicU64, collect_balances_us: AtomicU64, load_execute_us: AtomicU64, + load_execute_us_min: AtomicU64, + load_execute_us_max: AtomicU64, freeze_lock_us: AtomicU64, record_us: AtomicU64, commit_us: AtomicU64, find_and_send_votes_us: AtomicU64, wait_for_bank_success_us: AtomicU64, wait_for_bank_failure_us: AtomicU64, + num_batches_processed: AtomicU64, } impl ConsumeWorkerTimingMetrics { @@ -533,6 +545,21 @@ impl ConsumeWorkerTimingMetrics { self.load_execute_us.swap(0, Ordering::Relaxed), i64 ), + ( + "load_execute_us_min", + self.load_execute_us_min.swap(0, Ordering::Relaxed), + i64 + ), + ( + "load_execute_us_max", + self.load_execute_us_max.swap(0, Ordering::Relaxed), + i64 + ), + ( + "num_batches_processed", + self.num_batches_processed.swap(0, Ordering::Relaxed), + i64 + ), ( "freeze_lock_us", self.freeze_lock_us.swap(0, Ordering::Relaxed),