Struct mz_rocksdb::InstanceOptions

source ·
pub struct InstanceOptions<O, V, F> {
    pub cleanup_on_new: bool,
    pub cleanup_tries: usize,
    pub use_wal: bool,
    pub env: Env,
    pub bincode: O,
    pub merge_operator: Option<(String, F)>,
    pub(crate) v: PhantomData<V>,
}
Expand description

Fixed options to configure a RocksDBInstance. These are not tuning parameters, see the config modules for tuning. These are generally fixed within the binary.

Fields§

§cleanup_on_new: bool

Whether or not to clear state at the instance path before starting.

§cleanup_tries: usize

If cleanup_on_new, how many times to try.

§use_wal: bool

Whether or not to write writes to the wal. This is not in RocksDBTuningParameters because it applies to WriteOptions when creating WriteBatches.

§env: Env

A possibly shared RocksDB Env.

§bincode: O

The bincode options to use for serializing and deserializing values.

§merge_operator: Option<(String, F)>

A merge operator to use for associative merges, if any. The first item is the name of the operator to store in RocksDB for compatibility checks, and the second is the merge function.

§v: PhantomData<V>

Implementations§

source§

impl<O, V, F> InstanceOptions<O, V, F>
where O: Options + Copy + Send + Sync + 'static, V: DeserializeOwned + Serialize + Send + Sync + 'static, F: for<'a> Fn(&'a [u8], ValueIterator<'a, O, V>) -> V + Copy + Send + Sync + 'static,

source

pub fn new( env: Env, cleanup_tries: usize, merge_operator: Option<(String, F)>, bincode: O, ) -> Self

A new Options object with reasonable defaults.

source

pub(crate) fn as_rocksdb_options( &self, tuning_config: &RocksDBConfig, ) -> (RocksDBOptions, Option<WriteBufferManagerHandle>)

source

pub(crate) fn as_rocksdb_write_options(&self) -> WriteOptions

Auto Trait Implementations§

§

impl<O, V, F> Freeze for InstanceOptions<O, V, F>
where O: Freeze, F: Freeze,

§

impl<O, V, F> RefUnwindSafe for InstanceOptions<O, V, F>

§

impl<O, V, F> Send for InstanceOptions<O, V, F>
where O: Send, V: Send, F: Send,

§

impl<O, V, F> Sync for InstanceOptions<O, V, F>
where O: Sync, V: Sync, F: Sync,

§

impl<O, V, F> Unpin for InstanceOptions<O, V, F>
where O: Unpin, V: Unpin, F: Unpin,

§

impl<O, V, F> UnwindSafe for InstanceOptions<O, V, F>
where O: UnwindSafe, V: UnwindSafe, F: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T, U> CastInto<U> for T
where U: CastFrom<T>,

source§

fn cast_into(self) -> U

Performs the cast.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FutureExt for T

source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<P, R> ProtoType<R> for P
where R: RustType<P>,

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,