Relax late sync committee penalty (#2752)
## Issue Addressed Getting too many peers kicked due to slightly late sync committee messages as tested on.. under-performant hardware. ## Proposed Changes Only penalize if the message is more than one slot late. Still ignore the message- Co-authored-by: Divma <26765164+divagant-martian@users.noreply.github.com>
This commit is contained in:
parent
1790010260
commit
e2c0650d16
@ -1610,9 +1610,9 @@ impl<T: BeaconChainTypes> Worker<T> {
|
|||||||
metrics::register_sync_committee_error(&error);
|
metrics::register_sync_committee_error(&error);
|
||||||
|
|
||||||
match &error {
|
match &error {
|
||||||
SyncCommitteeError::FutureSlot { .. } | SyncCommitteeError::PastSlot { .. } => {
|
SyncCommitteeError::FutureSlot { .. } => {
|
||||||
/*
|
/*
|
||||||
* These errors can be triggered by a mismatch between our slot and the peer.
|
* This error can be triggered by a mismatch between our slot and the peer.
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
* The peer has published an invalid consensus message, _only_ if we trust our own clock.
|
* The peer has published an invalid consensus message, _only_ if we trust our own clock.
|
||||||
@ -1631,6 +1631,31 @@ impl<T: BeaconChainTypes> Worker<T> {
|
|||||||
// Do not propagate these messages.
|
// Do not propagate these messages.
|
||||||
self.propagate_validation_result(message_id, peer_id, MessageAcceptance::Ignore);
|
self.propagate_validation_result(message_id, peer_id, MessageAcceptance::Ignore);
|
||||||
}
|
}
|
||||||
|
SyncCommitteeError::PastSlot {
|
||||||
|
message_slot,
|
||||||
|
earliest_permissible_slot,
|
||||||
|
} => {
|
||||||
|
/*
|
||||||
|
* This error can be triggered by a mismatch between our slot and the peer.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* The peer has published an invalid consensus message, _only_ if we trust our own clock.
|
||||||
|
*/
|
||||||
|
trace!(
|
||||||
|
self.log,
|
||||||
|
"Sync committee message is not within the last MAXIMUM_GOSSIP_CLOCK_DISPARITY slots";
|
||||||
|
"peer_id" => %peer_id,
|
||||||
|
"type" => ?message_type,
|
||||||
|
);
|
||||||
|
|
||||||
|
// We tolerate messages that were just one slot late.
|
||||||
|
if *message_slot + 1 < *earliest_permissible_slot {
|
||||||
|
self.gossip_penalize_peer(peer_id, PeerAction::HighToleranceError);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Do not propagate these messages.
|
||||||
|
self.propagate_validation_result(message_id, peer_id, MessageAcceptance::Ignore);
|
||||||
|
}
|
||||||
SyncCommitteeError::EmptyAggregationBitfield => {
|
SyncCommitteeError::EmptyAggregationBitfield => {
|
||||||
/*
|
/*
|
||||||
* The aggregate had no signatures and is therefore worthless.
|
* The aggregate had no signatures and is therefore worthless.
|
||||||
|
Loading…
Reference in New Issue
Block a user