pub struct CompactionQueue { /* private fields */ }Expand description
Compaction queue manager for multiple shards.
Implementations§
Source§impl CompactionQueue
impl CompactionQueue
Sourcepub fn new(num_shards: usize, config: CompactionConfig) -> Self
pub fn new(num_shards: usize, config: CompactionConfig) -> Self
Create a new compaction queue.
Sourcepub fn schedule(&self, shard_id: ShardId, priority: CompactionPriority) -> bool
pub fn schedule(&self, shard_id: ShardId, priority: CompactionPriority) -> bool
Schedule compaction for a shard.
Sourcepub fn next_task(&self) -> Option<(ShardId, CompactionTask)>
pub fn next_task(&self) -> Option<(ShardId, CompactionTask)>
Get next task to process (from any shard).
Sourcepub fn active_compactions(&self) -> usize
pub fn active_compactions(&self) -> usize
Count active compactions.
Sourcepub fn can_start_compaction(&self) -> bool
pub fn can_start_compaction(&self) -> bool
Check if more compactions can start.
Sourcepub fn total_pending(&self) -> usize
pub fn total_pending(&self) -> usize
Total pending tasks across all shards.
Sourcepub fn is_shutdown(&self) -> bool
pub fn is_shutdown(&self) -> bool
Check if shutdown requested.
Sourcepub fn num_shards(&self) -> usize
pub fn num_shards(&self) -> usize
Number of shards.
Auto Trait Implementations§
impl !Freeze for CompactionQueue
impl RefUnwindSafe for CompactionQueue
impl Send for CompactionQueue
impl Sync for CompactionQueue
impl Unpin for CompactionQueue
impl UnsafeUnpin for CompactionQueue
impl UnwindSafe for CompactionQueue
Blanket Implementations§
impl<T> Allocation for T
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
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
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 more