Only gossip snapshot hashes for full snapshots (#20271)
This commit is contained in:
@@ -1,7 +1,9 @@
|
|||||||
use solana_gossip::cluster_info::{ClusterInfo, MAX_SNAPSHOT_HASHES};
|
use solana_gossip::cluster_info::{ClusterInfo, MAX_SNAPSHOT_HASHES};
|
||||||
use solana_runtime::{
|
use solana_runtime::{
|
||||||
snapshot_archive_info::SnapshotArchiveInfoGetter, snapshot_config::SnapshotConfig,
|
snapshot_archive_info::SnapshotArchiveInfoGetter,
|
||||||
snapshot_package::PendingSnapshotPackage, snapshot_utils,
|
snapshot_config::SnapshotConfig,
|
||||||
|
snapshot_package::{PendingSnapshotPackage, SnapshotType},
|
||||||
|
snapshot_utils,
|
||||||
};
|
};
|
||||||
use solana_sdk::{clock::Slot, hash::Hash};
|
use solana_sdk::{clock::Slot, hash::Hash};
|
||||||
use std::{
|
use std::{
|
||||||
@@ -58,12 +60,16 @@ impl SnapshotPackagerService {
|
|||||||
)
|
)
|
||||||
.expect("failed to archive snapshot package");
|
.expect("failed to archive snapshot package");
|
||||||
|
|
||||||
|
// NOTE: For backwards compatibility with version <=1.7, only _full_ snapshots
|
||||||
|
// can have their hashes pushed out to the cluster.
|
||||||
|
if snapshot_package.snapshot_type == SnapshotType::FullSnapshot {
|
||||||
hashes.push((snapshot_package.slot(), *snapshot_package.hash()));
|
hashes.push((snapshot_package.slot(), *snapshot_package.hash()));
|
||||||
while hashes.len() > MAX_SNAPSHOT_HASHES {
|
while hashes.len() > MAX_SNAPSHOT_HASHES {
|
||||||
hashes.remove(0);
|
hashes.remove(0);
|
||||||
}
|
}
|
||||||
cluster_info.push_snapshot_hashes(hashes.clone());
|
cluster_info.push_snapshot_hashes(hashes.clone());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
})
|
})
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user