pub struct ForcedPromotion {
pub collection: CollectionId,
pub range_id: RangeId,
pub dead_owner: NodeIdentity,
pub new_owner: NodeIdentity,
pub covers_watermark: bool,
pub evidence: Option<CatchUpEvidence>,
pub next: RangeOwnership,
}Expand description
A forced promotion of one owned range away from the dead member to the
best-available surviving replica. Unlike a planned hand-off this proceeds even
when the target cannot prove it covers the commit watermark — covers_watermark
records whether it could, so the audit trail captures any possible
committed-write loss. next is the fenced catalog entry (epoch bumped) that
activation installs.
Fields§
§collection: CollectionId§range_id: RangeId§dead_owner: NodeIdentity§new_owner: NodeIdentity§covers_watermark: boolWhether the promoted replica’s applied log covers the commit watermark. When
false, writes past the replica’s applied point may be lost — the price of
recovering a range whose owner is gone.
evidence: Option<CatchUpEvidence>The promoted replica’s catch-up evidence, if any was known.
next: RangeOwnershipTrait Implementations§
Source§impl Clone for ForcedPromotion
impl Clone for ForcedPromotion
Source§fn clone(&self) -> ForcedPromotion
fn clone(&self) -> ForcedPromotion
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 ForcedPromotion
impl Debug for ForcedPromotion
impl Eq for ForcedPromotion
Source§impl PartialEq for ForcedPromotion
impl PartialEq for ForcedPromotion
Source§fn eq(&self, other: &ForcedPromotion) -> bool
fn eq(&self, other: &ForcedPromotion) -> bool
Tests for
self and other values to be equal, and is used by ==.impl StructuralPartialEq for ForcedPromotion
Auto Trait Implementations§
impl Freeze for ForcedPromotion
impl RefUnwindSafe for ForcedPromotion
impl Send for ForcedPromotion
impl Sync for ForcedPromotion
impl Unpin for ForcedPromotion
impl UnsafeUnpin for ForcedPromotion
impl UnwindSafe for ForcedPromotion
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