pub enum DrainBlockReason {
NoSafeHandoffTarget,
NoReplacementReplica,
}Expand description
Why a range could not be scheduled off the draining member. Surfaced rather than silently skipped, so an operator sees exactly which range is holding the drain open (and removal blocked).
Variants§
NoSafeHandoffTarget
An owned range has no safe hand-off target — no replica is an active data member with catch-up evidence covering the commit watermark. Handing off to a node that has not caught up could lose committed writes.
NoReplacementReplica
A replicated range cannot shed the draining member’s copy without dropping below its replication factor, and no eligible member is free to host a replacement copy.
Trait Implementations§
Source§impl Clone for DrainBlockReason
impl Clone for DrainBlockReason
Source§fn clone(&self) -> DrainBlockReason
fn clone(&self) -> DrainBlockReason
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 moreimpl Copy for DrainBlockReason
Source§impl Debug for DrainBlockReason
impl Debug for DrainBlockReason
impl Eq for DrainBlockReason
Source§impl PartialEq for DrainBlockReason
impl PartialEq for DrainBlockReason
Source§fn eq(&self, other: &DrainBlockReason) -> bool
fn eq(&self, other: &DrainBlockReason) -> bool
Tests for
self and other values to be equal, and is used by ==.impl StructuralPartialEq for DrainBlockReason
Auto Trait Implementations§
impl Freeze for DrainBlockReason
impl RefUnwindSafe for DrainBlockReason
impl Send for DrainBlockReason
impl Sync for DrainBlockReason
impl Unpin for DrainBlockReason
impl UnsafeUnpin for DrainBlockReason
impl UnwindSafe for DrainBlockReason
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