pub enum ClusterLifecycleState {
Starting,
Restarting,
Bootstrapping,
Joining {
attempt: u32,
},
Ready {
nodes: usize,
},
Failed {
reason: String,
},
}Expand description
Discrete phase of this node’s cluster init.
Variants§
Starting
Tracker just created, no phase decision yet.
Restarting
Catalog already marked as bootstrapped — loading from disk.
Bootstrapping
This node is the elected bootstrapper — creating a fresh cluster.
Joining
Joining an existing cluster. attempt counts from 0.
Fields
Ready
Cluster init finished successfully. nodes is the number of
members the node observed at the moment of transition.
Failed
Cluster init failed terminally. reason is a short
human-readable description; see journalctl for the full
context.
Implementations§
Source§impl ClusterLifecycleState
impl ClusterLifecycleState
Sourcepub fn label(&self) -> &'static str
pub fn label(&self) -> &'static str
Short label used in the state= dimension of the
nodedb_cluster_state Prometheus gauge. Stable across restarts
so dashboards don’t break.
Sourcepub fn all_labels() -> &'static [&'static str]
pub fn all_labels() -> &'static [&'static str]
Every label this enum can produce. Used by the metrics endpoint to emit a one-hot gauge over the full state space.
Trait Implementations§
Source§impl Clone for ClusterLifecycleState
impl Clone for ClusterLifecycleState
Source§fn clone(&self) -> ClusterLifecycleState
fn clone(&self) -> ClusterLifecycleState
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 moreSource§impl Debug for ClusterLifecycleState
impl Debug for ClusterLifecycleState
Source§impl<'de> Deserialize<'de> for ClusterLifecycleState
impl<'de> Deserialize<'de> for ClusterLifecycleState
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
Source§impl PartialEq for ClusterLifecycleState
impl PartialEq for ClusterLifecycleState
Source§fn eq(&self, other: &ClusterLifecycleState) -> bool
fn eq(&self, other: &ClusterLifecycleState) -> bool
Tests for
self and other values to be equal, and is used by ==.Source§impl Serialize for ClusterLifecycleState
impl Serialize for ClusterLifecycleState
impl Eq for ClusterLifecycleState
impl StructuralPartialEq for ClusterLifecycleState
Auto Trait Implementations§
impl Freeze for ClusterLifecycleState
impl RefUnwindSafe for ClusterLifecycleState
impl Send for ClusterLifecycleState
impl Sync for ClusterLifecycleState
impl Unpin for ClusterLifecycleState
impl UnsafeUnpin for ClusterLifecycleState
impl UnwindSafe for ClusterLifecycleState
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
Source§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
Source§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
Source§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.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.