pub struct QuorumConfig {
pub mode: QuorumMode,
pub timeout: Option<Duration>,
}Expand description
Quorum configuration stored alongside ReplicationConfig.
Fields§
§mode: QuorumMode§timeout: Option<Duration>How long the coordinator waits for acks before giving up.
None = wait forever (use for strong consistency only when
you can tolerate the writer stalling on a partitioned region).
Implementations§
Source§impl QuorumConfig
impl QuorumConfig
Sourcepub fn async_commit() -> Self
pub fn async_commit() -> Self
Ack immediately. Loss tolerance = 0 under primary failure.
Sourcepub fn sync(min_replicas: usize) -> Self
pub fn sync(min_replicas: usize) -> Self
Wait for n replicas to ack (any region). Typical PG-like
“synchronous_commit = on, synchronous_standby_names = ‘ANY n’”.
Sourcepub fn regions<I, S>(regions: I) -> Self
pub fn regions<I, S>(regions: I) -> Self
Wait for at least one replica from each region in the set. Use this for disaster-recovery deployments across cloud regions.
pub fn with_timeout(self, timeout: Duration) -> Self
pub fn without_timeout(self) -> Self
Trait Implementations§
Source§impl Clone for QuorumConfig
impl Clone for QuorumConfig
Source§fn clone(&self) -> QuorumConfig
fn clone(&self) -> QuorumConfig
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 QuorumConfig
impl Debug for QuorumConfig
Source§impl Default for QuorumConfig
impl Default for QuorumConfig
Source§impl PartialEq for QuorumConfig
impl PartialEq for QuorumConfig
Source§fn eq(&self, other: &QuorumConfig) -> bool
fn eq(&self, other: &QuorumConfig) -> bool
Tests for
self and other values to be equal, and is used by ==.impl Eq for QuorumConfig
impl StructuralPartialEq for QuorumConfig
Auto Trait Implementations§
impl Freeze for QuorumConfig
impl RefUnwindSafe for QuorumConfig
impl Send for QuorumConfig
impl Sync for QuorumConfig
impl Unpin for QuorumConfig
impl UnsafeUnpin for QuorumConfig
impl UnwindSafe for QuorumConfig
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> 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