#[non_exhaustive]pub enum ServerEvent {
PeerUp(PeerId),
PeerDown {
peer: PeerId,
reason: PeerDownReason,
},
ConfigReloaded {
generation: u64,
},
GossipRound {
round: u64,
peers: u32,
},
AutoEjected {
peer: PeerId,
failures: u32,
},
RepairTriggered {
key_hash: u64,
dc: String,
},
ConnectionAccepted {
conn_id: ConnId,
role: ConnRoleTag,
local_addr: Option<SocketAddr>,
},
ConnectionClosed {
conn_id: ConnId,
reason: CloseReason,
},
Lagged {
missed: u64,
},
}Expand description
Cluster-wide event published on the broadcast channel.
The variants are non-exhaustive at the type level; consumers must use a wildcard arm so future additions remain non-breaking.
§Examples
use dynomite::embed::events::{ServerEvent, PeerDownReason};
let e = ServerEvent::PeerDown { peer: 7, reason: PeerDownReason::FailureDetector };
match e {
ServerEvent::PeerDown { peer, .. } => assert_eq!(peer, 7),
_ => panic!(),
}Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
PeerUp(PeerId)
A peer transitioned to a routable state.
PeerDown
A peer transitioned to an unroutable state.
ConfigReloaded
A configuration reload completed successfully.
GossipRound
A periodic gossip pass finished.
Fields
AutoEjected
Auto-eject policy ejected a peer.
RepairTriggered
Read-repair was triggered for a key.
Fields
ConnectionAccepted
A connection was accepted on a listener.
Fields
§
role: ConnRoleTagRole of the accepted connection.
§
local_addr: Option<SocketAddr>Local socket address; None for non-socket transports.
ConnectionClosed
A connection closed.
Fields
§
reason: CloseReasonWhy the connection closed.
Lagged
The receiver fell behind the broadcast tail and missed
missed events. The next recv will resume from the
freshest event in the buffer.
Trait Implementations§
Source§impl Clone for ServerEvent
impl Clone for ServerEvent
Source§fn clone(&self) -> ServerEvent
fn clone(&self) -> ServerEvent
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · 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 ServerEvent
impl RefUnwindSafe for ServerEvent
impl Send for ServerEvent
impl Sync for ServerEvent
impl Unpin for ServerEvent
impl UnsafeUnpin for ServerEvent
impl UnwindSafe for ServerEvent
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> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
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 moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.