pub enum RollbackDecision {
RollbackToMatchpoint {
matchpoint_vlsn: Vlsn,
start_vlsn: Vlsn,
},
HardRecovery {
matchpoint_vlsn: Vlsn,
last_txn_end: Vlsn,
},
NetworkRestore,
}Expand description
The action verifyRollback selects once a matchpoint search has completed.
Port of the ReplicaFeederSyncup.verifyRollback truth table.
Variants§
RollbackToMatchpoint
Roll the diverged tail back to the matchpoint, then resume streaming
from matchpoint + 1. A “normal” rollback that does not cross a
committed/aborted transaction end (lastTxnEnd <= matchpoint).
HardRecovery
The matchpoint would require rolling back past a transaction end that the replica has acknowledged. JE does a hard recovery (log truncation
- restart) when truncation is permissible.
NetworkRestore
No safe matchpoint / truncation not permissible — the replica must do a full network restore from the master.
Trait Implementations§
Source§impl Clone for RollbackDecision
impl Clone for RollbackDecision
Source§fn clone(&self) -> RollbackDecision
fn clone(&self) -> RollbackDecision
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 RollbackDecision
impl Debug for RollbackDecision
impl Eq for RollbackDecision
Source§impl PartialEq for RollbackDecision
impl PartialEq for RollbackDecision
Source§fn eq(&self, other: &RollbackDecision) -> bool
fn eq(&self, other: &RollbackDecision) -> bool
Tests for
self and other values to be equal, and is used by ==.impl StructuralPartialEq for RollbackDecision
Auto Trait Implementations§
impl Freeze for RollbackDecision
impl RefUnwindSafe for RollbackDecision
impl Send for RollbackDecision
impl Sync for RollbackDecision
impl Unpin for RollbackDecision
impl UnsafeUnpin for RollbackDecision
impl UnwindSafe for RollbackDecision
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
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> 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 more