Struct re_chunk_store::store::ChunkStoreConfig
source · pub struct ChunkStoreConfig {
pub enable_changelog: bool,
pub chunk_max_bytes: u64,
pub chunk_max_rows: u64,
pub chunk_max_rows_if_unsorted: u64,
}
Fields§
§enable_changelog: bool
If true
(the default), the store will emit events when its contents are modified in
any way (insertion, GC), that can be subscribed to.
Leaving this disabled can lead to major performance improvements on the ingestion path in some workloads, provided that the subscribers aren’t needed (e.g. headless mode).
chunk_max_bytes: u64
What is the threshold, in bytes, after which a Chunk
cannot be compacted any further?
This is a multi-dimensional trade-off:
- Larger chunks lead to less fixed overhead introduced by metadata, indices and such. Good.
- Larger chunks lead to slower query execution on some unhappy paths. Bad.
- Larger chunks lead to slower and slower compaction as chunks grow larger. Bad.
- Larger chunks lead to coarser garbage collection. Good or bad depending on use case.
- Larger chunks lead to less precision in e.g. the time panel. Bad.
Empirical testing shows that the space overhead gains rapidly diminish beyond ~1000 rows, which is the default row threshold. The default byte threshold is set to 8MiB, which is a reasonable unit of work when e.g. sending chunks over the network.
chunk_max_rows: u64
What is the threshold, in rows, after which a Chunk
cannot be compacted any further?
This specifically applies to time-sorted chunks.
See also ChunkStoreConfig::chunk_max_rows_if_unsorted
.
This is a multi-dimensional trade-off:
- Larger chunks lead to less fixed overhead introduced by metadata, indices and such. Good.
- Larger chunks lead to slower query execution on some unhappy paths. Bad.
- Larger chunks lead to slower and slower compaction as chunks grow larger. Bad.
- Larger chunks lead to coarser garbage collection. Good or bad depending on use case.
- Larger chunks lead to less precision in e.g. the time panel. Bad.
Empirical testing shows that the space overhead gains rapidly diminish beyond ~1000 rows, which is the default row threshold. The default byte threshold is set to 8MiB, which is a reasonable unit of work when e.g. sending chunks over the network.
chunk_max_rows_if_unsorted: u64
What is the threshold, in rows, after which a Chunk
cannot be compacted any further?
This specifically applies to non time-sorted chunks.
See also ChunkStoreConfig::chunk_max_rows
.
This is a multi-dimensional trade-off:
- Larger chunks lead to less fixed overhead introduced by metadata, indices and such. Good.
- Larger chunks lead to slower query execution on some unhappy paths. Bad.
- Larger chunks lead to slower and slower compaction as chunks grow larger. Bad.
- Larger chunks lead to coarser garbage collection. Good or bad depending on use case.
- Larger chunks lead to less precision in e.g. the time panel. Bad.
Empirical testing shows that the space overhead gains rapidly diminish beyond ~1000 rows, which is the default row threshold. The default byte threshold is set to 8MiB, which is a reasonable unit of work when e.g. sending chunks over the network.
Implementations§
source§impl ChunkStoreConfig
impl ChunkStoreConfig
sourcepub const DEFAULT: Self = _
pub const DEFAULT: Self = _
Default configuration, applicable to most use cases, according to empirical testing.
sourcepub const COMPACTION_DISABLED: Self = _
pub const COMPACTION_DISABLED: Self = _
Self::DEFAULT
, but with compaction entirely disabled.
sourcepub const CHANGELOG_DISABLED: Self = _
pub const CHANGELOG_DISABLED: Self = _
Self::DEFAULT
, but with changelog disabled.
sourcepub const ALL_DISABLED: Self = _
pub const ALL_DISABLED: Self = _
All features disabled.
sourcepub const ENV_STORE_ENABLE_CHANGELOG: &'static str = "RERUN_STORE_ENABLE_CHANGELOG"
pub const ENV_STORE_ENABLE_CHANGELOG: &'static str = "RERUN_STORE_ENABLE_CHANGELOG"
Environment variable to configure Self::enable_changelog
.
sourcepub const ENV_CHUNK_MAX_BYTES: &'static str = "RERUN_CHUNK_MAX_BYTES"
pub const ENV_CHUNK_MAX_BYTES: &'static str = "RERUN_CHUNK_MAX_BYTES"
Environment variable to configure Self::chunk_max_bytes
.
sourcepub const ENV_CHUNK_MAX_ROWS: &'static str = "RERUN_CHUNK_MAX_ROWS"
pub const ENV_CHUNK_MAX_ROWS: &'static str = "RERUN_CHUNK_MAX_ROWS"
Environment variable to configure Self::chunk_max_rows
.
sourcepub const ENV_CHUNK_MAX_ROWS_IF_UNSORTED: &'static str = "RERUN_CHUNK_MAX_ROWS_IF_UNSORTED"
pub const ENV_CHUNK_MAX_ROWS_IF_UNSORTED: &'static str = "RERUN_CHUNK_MAX_ROWS_IF_UNSORTED"
Environment variable to configure Self::chunk_max_rows_if_unsorted
.
sourcepub fn from_env() -> ChunkStoreResult<Self>
pub fn from_env() -> ChunkStoreResult<Self>
Creates a new ChunkStoreConfig
using the default values, optionally overridden
through the environment.
See Self::apply_env
.
sourcepub fn apply_env(&self) -> ChunkStoreResult<Self>
pub fn apply_env(&self) -> ChunkStoreResult<Self>
Returns a copy of self
, overriding existing fields with values from the environment if
they are present.
See Self::ENV_STORE_ENABLE_CHANGELOG
, Self::ENV_CHUNK_MAX_BYTES
, Self::ENV_CHUNK_MAX_ROWS
and Self::ENV_CHUNK_MAX_ROWS_IF_UNSORTED
.
Trait Implementations§
source§impl Clone for ChunkStoreConfig
impl Clone for ChunkStoreConfig
source§fn clone(&self) -> ChunkStoreConfig
fn clone(&self) -> ChunkStoreConfig
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for ChunkStoreConfig
impl Debug for ChunkStoreConfig
source§impl Default for ChunkStoreConfig
impl Default for ChunkStoreConfig
source§impl PartialEq for ChunkStoreConfig
impl PartialEq for ChunkStoreConfig
source§fn eq(&self, other: &ChunkStoreConfig) -> bool
fn eq(&self, other: &ChunkStoreConfig) -> bool
self
and other
values to be equal, and is used
by ==
.impl Eq for ChunkStoreConfig
impl StructuralPartialEq for ChunkStoreConfig
Auto Trait Implementations§
impl Freeze for ChunkStoreConfig
impl RefUnwindSafe for ChunkStoreConfig
impl Send for ChunkStoreConfig
impl Sync for ChunkStoreConfig
impl Unpin for ChunkStoreConfig
impl UnwindSafe for ChunkStoreConfig
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> CheckedAs for T
impl<T> CheckedAs for T
source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§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>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§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>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§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.§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.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.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
key
and return true
if they are equal.§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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 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>
T
in a tonic::Request