AcctIdx: metrics for loading from disk (#20124)

This commit is contained in:
Jeff Washington (jwash) 2021-09-23 08:14:08 -05:00 committed by GitHub
parent 4d3e32803f
commit cb9d93525b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 39 additions and 4 deletions

View File

@ -14,6 +14,10 @@ pub struct BucketMapHolderStats {
pub entries_from_mem: AtomicU64, pub entries_from_mem: AtomicU64,
pub entry_missing_us: AtomicU64, pub entry_missing_us: AtomicU64,
pub entries_missing: AtomicU64, pub entries_missing: AtomicU64,
pub load_disk_found_count: AtomicU64,
pub load_disk_found_us: AtomicU64,
pub load_disk_missing_count: AtomicU64,
pub load_disk_missing_us: AtomicU64,
pub updates_in_mem: AtomicU64, pub updates_in_mem: AtomicU64,
pub items: AtomicU64, pub items: AtomicU64,
pub keys: AtomicU64, pub keys: AtomicU64,
@ -138,6 +142,26 @@ impl BucketMapHolderStats {
self.entry_mem_us.swap(0, Ordering::Relaxed) / 1000, self.entry_mem_us.swap(0, Ordering::Relaxed) / 1000,
i64 i64
), ),
(
"load_disk_found_count",
self.load_disk_found_count.swap(0, Ordering::Relaxed),
i64
),
(
"load_disk_found_us",
self.load_disk_found_us.swap(0, Ordering::Relaxed) / 1000,
i64
),
(
"load_disk_missing_count",
self.load_disk_missing_count.swap(0, Ordering::Relaxed),
i64
),
(
"load_disk_missing_us",
self.load_disk_missing_us.swap(0, Ordering::Relaxed) / 1000,
i64
),
( (
"entries_missing", "entries_missing",
self.entries_missing.swap(0, Ordering::Relaxed), self.entries_missing.swap(0, Ordering::Relaxed),

View File

@ -106,10 +106,21 @@ impl<T: IndexValue> InMemAccountsIndex<T> {
} }
fn load_from_disk(&self, pubkey: &Pubkey) -> Option<(SlotList<T>, RefCount)> { fn load_from_disk(&self, pubkey: &Pubkey) -> Option<(SlotList<T>, RefCount)> {
self.storage self.storage.disk.as_ref().and_then(|disk| {
.disk let m = Measure::start("load_disk_found_count");
.as_ref() let entry_disk = disk.read_value(pubkey);
.and_then(|disk| disk.read_value(pubkey)) match &entry_disk {
Some(_) => {
Self::update_time_stat(&self.stats().load_disk_found_us, m);
Self::update_stat(&self.stats().load_disk_found_count, 1);
}
None => {
Self::update_time_stat(&self.stats().load_disk_missing_us, m);
Self::update_stat(&self.stats().load_disk_missing_count, 1);
}
}
entry_disk
})
} }
fn load_account_entry_from_disk(&self, pubkey: &Pubkey) -> Option<AccountMapEntry<T>> { fn load_account_entry_from_disk(&self, pubkey: &Pubkey) -> Option<AccountMapEntry<T>> {