#[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