From 5b10e0aa22c1d5701e9634e2c7d206950adc6c51 Mon Sep 17 00:00:00 2001 From: qima Date: Thu, 14 Nov 2024 00:01:01 +0800 Subject: [PATCH] fix(node): populate records_by_bucket cache during restart --- sn_networking/src/record_store.rs | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/sn_networking/src/record_store.rs b/sn_networking/src/record_store.rs index e3eb672d6c..1e54ceb6e6 100644 --- a/sn_networking/src/record_store.rs +++ b/sn_networking/src/record_store.rs @@ -371,13 +371,25 @@ impl NodeRecordStore { }; let records = Self::update_records_from_an_existing_store(&config, &encryption_details); + let local_address = NetworkAddress::from_peer(local_id); + + // Initialize records_by_bucket + let mut records_by_bucket: HashMap> = HashMap::new(); + for (key, (addr, _record_type)) in records.iter() { + let distance = local_address.distance(addr); + let bucket = distance.ilog2().unwrap_or_default(); + records_by_bucket + .entry(bucket) + .or_default() + .insert(key.clone()); + } let cache_size = config.records_cache_size; let mut record_store = NodeRecordStore { - local_address: NetworkAddress::from_peer(local_id), + local_address, config, records, - records_by_bucket: HashMap::new(), + records_by_bucket, records_cache: RecordCache::new(cache_size), network_event_sender, local_swarm_cmd_sender: swarm_cmd_sender,