pub struct MergePolicyConfig {
pub min_num_segments: usize,
pub min_layer_size: u32,
pub level_log_size: f64,
}Expand description
Tunable parameters for the segment-merge policy.
The defaults match the Cluster 9 plan: minimum 8 segments per merge,
level_log_size = 0.75 (tantivy default — restated explicitly so tests can
assert the policy was set), and min_layer_size set to 100 documents.
§Note on min_layer_size
Tantivy’s LogMergePolicy::min_layer_size is denominated in document
count, not bytes. The Cluster 9 plan asked for “10 MiB” which has no
direct mapping in tantivy 0.25; we substitute 100 documents as a
conservative proxy. Operators can override via MergePolicyConfig::min_layer_size.
Fields§
§min_num_segments: usizeMinimum number of segments that may be merged together.
min_layer_size: u32Minimum segment size (in documents) under which all segments are considered to belong to the same level.
level_log_size: f64Ratio between two consecutive levels.
Implementations§
Source§impl MergePolicyConfig
impl MergePolicyConfig
Sourcepub fn to_tantivy(&self) -> LogMergePolicy
pub fn to_tantivy(&self) -> LogMergePolicy
Build a tantivy LogMergePolicy from this configuration.
Trait Implementations§
Source§impl Clone for MergePolicyConfig
impl Clone for MergePolicyConfig
Source§fn clone(&self) -> MergePolicyConfig
fn clone(&self) -> MergePolicyConfig
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for MergePolicyConfig
impl Debug for MergePolicyConfig
Auto Trait Implementations§
impl Freeze for MergePolicyConfig
impl RefUnwindSafe for MergePolicyConfig
impl Send for MergePolicyConfig
impl Sync for MergePolicyConfig
impl Unpin for MergePolicyConfig
impl UnsafeUnpin for MergePolicyConfig
impl UnwindSafe for MergePolicyConfig
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
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>
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>
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 more