pub struct ElectionCoordinator;Expand description
The quorum-gated election state machine.
Implementations§
Source§impl ElectionCoordinator
impl ElectionCoordinator
Sourcepub fn run(
req: &ElectionRequest,
tx: &mut dyn ElectionTransport,
timeout: Duration,
) -> ElectionOutcome
pub fn run( req: &ElectionRequest, tx: &mut dyn ElectionTransport, timeout: Duration, ) -> ElectionOutcome
Run an election for req, driving the cluster through tx, bounded
by timeout (use randomized_election_timeout).
The flow is: electability guard → dry-run probe (no term bump) → real election (bump term, collect votes) → promote on majority. See the module docs for the full contract.
Auto Trait Implementations§
impl Freeze for ElectionCoordinator
impl RefUnwindSafe for ElectionCoordinator
impl Send for ElectionCoordinator
impl Sync for ElectionCoordinator
impl Unpin for ElectionCoordinator
impl UnsafeUnpin for ElectionCoordinator
impl UnwindSafe for ElectionCoordinator
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> 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