pub struct MessageOverlapMerge { /* private fields */ }Expand description
Detects network partitions by comparing message hashes across DHT records.
Joins peers whose published hashes do not overlap with local message history.
Implementations§
Source§impl MessageOverlapMerge
impl MessageOverlapMerge
Sourcepub fn new(
record_publisher: RecordPublisher,
gossip_sender: GossipSender,
gossip_receiver: GossipReceiver,
cancel_token: CancellationToken,
max_join_peers: usize,
initial_interval: Duration,
base_interval: Duration,
max_jitter: Duration,
) -> Result<Self>
pub fn new( record_publisher: RecordPublisher, gossip_sender: GossipSender, gossip_receiver: GossipReceiver, cancel_token: CancellationToken, max_join_peers: usize, initial_interval: Duration, base_interval: Duration, max_jitter: Duration, ) -> Result<Self>
Create a new split-brain detector.
Trait Implementations§
Source§impl Clone for MessageOverlapMerge
impl Clone for MessageOverlapMerge
Source§fn clone(&self) -> MessageOverlapMerge
fn clone(&self) -> MessageOverlapMerge
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreAuto Trait Implementations§
impl Freeze for MessageOverlapMerge
impl RefUnwindSafe for MessageOverlapMerge
impl Send for MessageOverlapMerge
impl Sync for MessageOverlapMerge
impl Unpin for MessageOverlapMerge
impl UnsafeUnpin for MessageOverlapMerge
impl UnwindSafe for MessageOverlapMerge
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more