pub struct DrainStatus {
pub member: NodeIdentity,
pub is_member: bool,
pub is_draining: bool,
pub owned_ranges: Vec<(CollectionId, RangeId)>,
pub replicated_ranges: Vec<(CollectionId, RangeId)>,
pub planned_steps: usize,
pub blocked: Vec<DrainBlock>,
pub removable: bool,
}Expand description
A snapshot of one member’s drain posture for operator/status reporting: its draining flag, the ranges it still owns and replicates, the count of steps a drain would schedule, the ranges currently blocking it, and whether it is removable right now.
Fields§
§member: NodeIdentity§is_member: bool§is_draining: bool§owned_ranges: Vec<(CollectionId, RangeId)>§replicated_ranges: Vec<(CollectionId, RangeId)>§planned_steps: usize§blocked: Vec<DrainBlock>§removable: boolTrue when the member is draining and depends on no range — a
commit_drain_removal would succeed.
Trait Implementations§
Source§impl Clone for DrainStatus
impl Clone for DrainStatus
Source§fn clone(&self) -> DrainStatus
fn clone(&self) -> DrainStatus
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 DrainStatus
impl Debug for DrainStatus
impl Eq for DrainStatus
Source§impl PartialEq for DrainStatus
impl PartialEq for DrainStatus
Source§fn eq(&self, other: &DrainStatus) -> bool
fn eq(&self, other: &DrainStatus) -> bool
Tests for
self and other values to be equal, and is used by ==.impl StructuralPartialEq for DrainStatus
Auto Trait Implementations§
impl Freeze for DrainStatus
impl RefUnwindSafe for DrainStatus
impl Send for DrainStatus
impl Sync for DrainStatus
impl Unpin for DrainStatus
impl UnsafeUnpin for DrainStatus
impl UnwindSafe for DrainStatus
Blanket Implementations§
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<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§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.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> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request