pub enum GossipMessage {
Ping {
seq_no: u64,
from: String,
updates: Vec<MemberStateUpdate>,
},
Ack {
seq_no: u64,
from: String,
updates: Vec<MemberStateUpdate>,
},
PingReq {
seq_no: u64,
from: String,
target: String,
target_addr: SocketAddr,
updates: Vec<MemberStateUpdate>,
},
IndirectAck {
seq_no: u64,
from: String,
target: String,
updates: Vec<MemberStateUpdate>,
},
Join {
member: GossipMember,
},
JoinAck {
members: Vec<GossipMember>,
},
Leave {
node_id: String,
incarnation: u64,
},
SyncRequest {
from: String,
},
SyncResponse {
members: Vec<GossipMember>,
},
}Expand description
Types of gossip messages
Variants§
Ping
Ping request for failure detection
Ack
Ping acknowledgement
PingReq
Request to ping another node on behalf of requester
IndirectAck
Indirect ack (forwarded from target)
Join
Join request from new node
Fields
§
member: GossipMemberJoinAck
Join response with current membership
Fields
§
members: Vec<GossipMember>Leave
Graceful leave notification
SyncRequest
Full state sync request
SyncResponse
Full state sync response
Fields
§
members: Vec<GossipMember>Trait Implementations§
Source§impl Clone for GossipMessage
impl Clone for GossipMessage
Source§fn clone(&self) -> GossipMessage
fn clone(&self) -> GossipMessage
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 moreSource§impl Debug for GossipMessage
impl Debug for GossipMessage
Source§impl<'de> Deserialize<'de> for GossipMessage
impl<'de> Deserialize<'de> for GossipMessage
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for GossipMessage
impl RefUnwindSafe for GossipMessage
impl Send for GossipMessage
impl Sync for GossipMessage
impl Unpin for GossipMessage
impl UnsafeUnpin for GossipMessage
impl UnwindSafe for GossipMessage
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