pub struct RedbLogStorage { /* private fields */ }Expand description
Persistent Raft log storage backed by redb.
Implementations§
Trait Implementations§
Source§impl LogStorage for RedbLogStorage
impl LogStorage for RedbLogStorage
Source§fn append(&mut self, entries: &[LogEntry]) -> Result<()>
fn append(&mut self, entries: &[LogEntry]) -> Result<()>
Persist log entries (must be durable before returning).
Source§fn truncate(&mut self, index: u64) -> Result<()>
fn truncate(&mut self, index: u64) -> Result<()>
Truncate log entries from
index onward (inclusive).Source§fn load_entries_after(&self, snapshot_index: u64) -> Result<Vec<LogEntry>>
fn load_entries_after(&self, snapshot_index: u64) -> Result<Vec<LogEntry>>
Load all entries after
snapshot_index on startup.Source§fn compact(&mut self, index: u64, term: u64) -> Result<()>
fn compact(&mut self, index: u64, term: u64) -> Result<()>
Compact: discard entries up to
index, save snapshot metadata.Source§fn snapshot_metadata(&self) -> (u64, u64)
fn snapshot_metadata(&self) -> (u64, u64)
Return (last_included_index, last_included_term) of the latest snapshot.
Source§fn save_hard_state(&mut self, state: &HardState) -> Result<()>
fn save_hard_state(&mut self, state: &HardState) -> Result<()>
Persist hard state (current_term, voted_for).
Source§fn load_hard_state(&self) -> Result<HardState>
fn load_hard_state(&self) -> Result<HardState>
Load hard state on startup.
Auto Trait Implementations§
impl Freeze for RedbLogStorage
impl !RefUnwindSafe for RedbLogStorage
impl Send for RedbLogStorage
impl Sync for RedbLogStorage
impl Unpin for RedbLogStorage
impl UnsafeUnpin for RedbLogStorage
impl !UnwindSafe for RedbLogStorage
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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> 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> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.