From 0cc97689f9ad289d710657f3eaf586761f1ac5a4 Mon Sep 17 00:00:00 2001 From: "Jeff Washington (jwash)" Date: Thu, 5 May 2022 17:22:48 -0500 Subject: [PATCH] add stats for stakes_cache_check_and_store_us (#24349) * add stats for stakes_cache_check_and_store_us * remove redundant metrics --- runtime/src/accounts_db.rs | 12 ++++++++++-- runtime/src/bank.rs | 11 ++++++++++- 2 files changed, 20 insertions(+), 3 deletions(-) diff --git a/runtime/src/accounts_db.rs b/runtime/src/accounts_db.rs index afb4719a2ffdf0..612871f812e968 100644 --- a/runtime/src/accounts_db.rs +++ b/runtime/src/accounts_db.rs @@ -1052,7 +1052,7 @@ pub struct AccountsDb { pub bank_hashes: RwLock>, - stats: AccountsStats, + pub stats: AccountsStats, clean_accounts_stats: CleanAccountsStats, @@ -1113,7 +1113,7 @@ pub struct AccountsDb { } #[derive(Debug, Default)] -struct AccountsStats { +pub struct AccountsStats { delta_hash_scan_time_total_us: AtomicU64, delta_hash_accumulate_time_total_us: AtomicU64, delta_hash_num: AtomicU64, @@ -1125,6 +1125,7 @@ struct AccountsStats { store_update_index: AtomicU64, store_handle_reclaims: AtomicU64, store_append_accounts: AtomicU64, + pub stakes_cache_check_and_store_us: AtomicU64, store_find_store: AtomicU64, store_num_accounts: AtomicU64, store_total_data: AtomicU64, @@ -6574,6 +6575,13 @@ impl AccountsDb { self.stats.store_append_accounts.swap(0, Ordering::Relaxed), i64 ), + ( + "stakes_cache_check_and_store_us", + self.stats + .stakes_cache_check_and_store_us + .swap(0, Ordering::Relaxed), + i64 + ), ( "find_storage", self.stats.store_find_store.swap(0, Ordering::Relaxed), diff --git a/runtime/src/bank.rs b/runtime/src/bank.rs index 154888d4ca201a..b6c21cc0f2b41e 100644 --- a/runtime/src/bank.rs +++ b/runtime/src/bank.rs @@ -5815,8 +5815,15 @@ impl Bank { self.rc .accounts .store_slow_cached(self.slot(), pubkey, account); - + let mut m = Measure::start("stakes_cache.check_and_store"); self.stakes_cache.check_and_store(pubkey, account); + m.stop(); + self.rc + .accounts + .accounts_db + .stats + .stakes_cache_check_and_store_us + .fetch_add(m.as_us(), Relaxed); } pub fn force_flush_accounts_cache(&self) { @@ -6543,6 +6550,8 @@ impl Bank { load_result, execution_results[i].was_executed_successfully(), ) { + // note that this could get timed to: self.rc.accounts.accounts_db.stats.stakes_cache_check_and_store_us, + // but this code path is captured separately in ExecuteTimingType::UpdateStakesCacheUs let message = tx.message(); for (_i, (pubkey, account)) in (0..message.account_keys().len()).zip(loaded_transaction.accounts.iter())