pub enum CompactionStrategy {
Evict(f64),
Retain(usize),
Min(Box<CompactionStrategy>, Box<CompactionStrategy>),
Max(Box<CompactionStrategy>, Box<CompactionStrategy>),
}Expand description
Strategy for choosing what to evict
Variants§
Evict(f64)
Evict a percentage of messages
Retain(usize)
Retain the last N messages
Min(Box<CompactionStrategy>, Box<CompactionStrategy>)
Take minimum of two strategies (more conservative)
Max(Box<CompactionStrategy>, Box<CompactionStrategy>)
Take maximum of two strategies (more aggressive)
Implementations§
Source§impl CompactionStrategy
impl CompactionStrategy
Sourcepub fn calculate_eviction_range(
&self,
messages: &[MessageMeta],
retention_window: usize,
) -> Option<EvictionRange>
pub fn calculate_eviction_range( &self, messages: &[MessageMeta], retention_window: usize, ) -> Option<EvictionRange>
Sourcepub fn filter_droppable(
messages: &[MessageMeta],
range: &EvictionRange,
) -> Vec<usize>
pub fn filter_droppable( messages: &[MessageMeta], range: &EvictionRange, ) -> Vec<usize>
Filter out droppable messages from a range Returns indices of non-droppable messages to summarize
Trait Implementations§
Source§impl Clone for CompactionStrategy
impl Clone for CompactionStrategy
Source§fn clone(&self) -> CompactionStrategy
fn clone(&self) -> CompactionStrategy
Returns a duplicate of the value. Read more
1.0.0 · 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 CompactionStrategy
impl Debug for CompactionStrategy
Source§impl Default for CompactionStrategy
impl Default for CompactionStrategy
Source§impl<'de> Deserialize<'de> for CompactionStrategy
impl<'de> Deserialize<'de> for CompactionStrategy
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for CompactionStrategy
impl RefUnwindSafe for CompactionStrategy
impl Send for CompactionStrategy
impl Sync for CompactionStrategy
impl Unpin for CompactionStrategy
impl UnwindSafe for CompactionStrategy
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<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> 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 moreCreates a shared type from an unshared type.