pub enum ElectionError {
Failed(String),
HigherTerm(u64),
TermConflict {
current: u64,
received: u64,
},
LogConflict {
index: u64,
expected_term: u64,
actual_term: u64,
},
QuorumFailure {
required: usize,
succeed: usize,
},
LeadershipConsensus(String),
NoVotingMemberFound {
candidate_id: u32,
},
}
Variants§
Failed(String)
General election process failure
HigherTerm(u64)
Stale term detection (Section 5.1 Raft paper)
TermConflict
Term number inconsistency
LogConflict
Log inconsistency during vote requests (Section 5.4.1 Raft paper)
QuorumFailure
Quorum not achieved (Section 5.2 Raft paper)
LeadershipConsensus(String)
Leadership handoff failures
NoVotingMemberFound
Isolated node scenario
Trait Implementations§
Source§impl Debug for ElectionError
impl Debug for ElectionError
Source§impl Display for ElectionError
impl Display for ElectionError
Source§impl Error for ElectionError
impl Error for ElectionError
1.30.0 · Source§fn source(&self) -> Option<&(dyn Error + 'static)>
fn source(&self) -> Option<&(dyn Error + 'static)>
Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§fn description(&self) -> &str
fn description(&self) -> &str
👎Deprecated since 1.42.0: use the Display impl or to_string()
Source§impl From<ElectionError> for ConsensusError
impl From<ElectionError> for ConsensusError
Source§fn from(source: ElectionError) -> Self
fn from(source: ElectionError) -> Self
Converts to this type from the input type.
Source§impl From<ElectionError> for Error
impl From<ElectionError> for Error
Source§fn from(e: ElectionError) -> Self
fn from(e: ElectionError) -> Self
Converts to this type from the input type.
Auto Trait Implementations§
impl Freeze for ElectionError
impl RefUnwindSafe for ElectionError
impl Send for ElectionError
impl Sync for ElectionError
impl Unpin for ElectionError
impl UnwindSafe for ElectionError
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> 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> 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