pub struct MembershipState {
pub members: Vec<Member>,
pub reachability: Reachability,
}Fields§
§members: Vec<Member>§reachability: ReachabilityImplementations§
Source§impl MembershipState
impl MembershipState
pub fn new() -> Self
pub fn add_or_update(&mut self, m: Member)
pub fn remove(&mut self, addr: &Address)
pub fn up_members(&self) -> Vec<&Member>
pub fn unreachable_addresses(&self) -> BTreeSet<String>
pub fn member_count(&self) -> usize
Sourcepub fn apply_leader_actions(&mut self) -> Vec<ClusterEvent>
pub fn apply_leader_actions(&mut self) -> Vec<ClusterEvent>
Run the leader’s per-tick transition logic against the current
state. Returns the ClusterEvents the daemon should publish
(membership status flips, removals).
Phase 6.C of docs/full-port-plan.md. Pure function — keeps
the daemon actor itself trivial: collect events, then publish
onto crate::events::ClusterEventBus.
Sourcepub fn join(&mut self, m: Member) -> ClusterEvent
pub fn join(&mut self, m: Member) -> ClusterEvent
Insert m as a Joining member and emit the MemberJoined
event for the daemon to publish.
Sourcepub fn leave(&mut self, addr: &Address) -> Option<ClusterEvent>
pub fn leave(&mut self, addr: &Address) -> Option<ClusterEvent>
Mark addr as leaving. Returns the published event if the
transition was valid, None if no such member exists.
Trait Implementations§
Source§impl Clone for MembershipState
impl Clone for MembershipState
Source§fn clone(&self) -> MembershipState
fn clone(&self) -> MembershipState
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 MembershipState
impl Debug for MembershipState
Source§impl Default for MembershipState
impl Default for MembershipState
Source§fn default() -> MembershipState
fn default() -> MembershipState
Returns the “default value” for a type. Read more
Source§impl<'de> Deserialize<'de> for MembershipState
impl<'de> Deserialize<'de> for MembershipState
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 MembershipState
impl RefUnwindSafe for MembershipState
impl Send for MembershipState
impl Sync for MembershipState
impl Unpin for MembershipState
impl UnsafeUnpin for MembershipState
impl UnwindSafe for MembershipState
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