pub struct PlacementPolicy {
pub balance_tolerance: f64,
pub hotspot_load_factor: f64,
}Expand description
The tunables that gate when imbalance and traffic are worth a move.
The defaults are deliberately slack: a cluster within 10% of its fair share is “balanced enough” not to churn ownership, and a hotspot must run at 2× the cluster-mean traffic before it is worth spreading. Tight thresholds would make the planner thrash on noise.
Fields§
§balance_tolerance: f64Fractional tolerance around a member’s fair share. A member is “over” only
when its bytes-used exceeds fair * (1 + balance_tolerance); a move’s
target must have room under fair * (1 + balance_tolerance). Larger values
tolerate more imbalance for less churn.
hotspot_load_factor: f64How many times the cluster-mean range traffic a range must serve to count
as a hotspot. 2.0 means “twice the average”.
Trait Implementations§
Source§impl Clone for PlacementPolicy
impl Clone for PlacementPolicy
Source§fn clone(&self) -> PlacementPolicy
fn clone(&self) -> PlacementPolicy
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 moreimpl Copy for PlacementPolicy
Source§impl Debug for PlacementPolicy
impl Debug for PlacementPolicy
Source§impl Default for PlacementPolicy
impl Default for PlacementPolicy
Source§impl PartialEq for PlacementPolicy
impl PartialEq for PlacementPolicy
Source§fn eq(&self, other: &PlacementPolicy) -> bool
fn eq(&self, other: &PlacementPolicy) -> bool
Tests for
self and other values to be equal, and is used by ==.impl StructuralPartialEq for PlacementPolicy
Auto Trait Implementations§
impl Freeze for PlacementPolicy
impl RefUnwindSafe for PlacementPolicy
impl Send for PlacementPolicy
impl Sync for PlacementPolicy
impl Unpin for PlacementPolicy
impl UnsafeUnpin for PlacementPolicy
impl UnwindSafe for PlacementPolicy
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<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