pub struct AdaptiveCacheAdapter { /* private fields */ }Expand description
Adapter that wraps AdaptiveCache for metadata-only caching.
This adapter uses AdaptiveCache<()> (unit type) to track cache metadata
without storing actual values. This is useful when the actual data is
already stored in a persistent layer (like redb), and you only need
metadata tracking with intelligent TTL adjustment.
§Benefits over LRUCache
- Adaptive TTL: Frequently accessed items get longer TTL
- Cold item detection: Rarely accessed items get shorter TTL
- Better memory efficiency for cold items
§Example
use do_memory_storage_redb::{AdaptiveCacheAdapter, AdaptiveCacheConfig};
use std::time::Duration;
let config = AdaptiveCacheConfig {
max_size: 1000,
default_ttl: Duration::from_secs(1800),
..Default::default()
};
let cache = AdaptiveCacheAdapter::new(config);Implementations§
Source§impl AdaptiveCacheAdapter
impl AdaptiveCacheAdapter
Sourcepub fn new(config: AdaptiveCacheConfig) -> Self
pub fn new(config: AdaptiveCacheConfig) -> Self
Create a new adaptive cache adapter with the given configuration
Sourcepub fn with_defaults() -> Self
pub fn with_defaults() -> Self
Create a new adaptive cache adapter with default configuration
Sourcepub fn inner(&self) -> &AdaptiveCache<()>
pub fn inner(&self) -> &AdaptiveCache<()>
Get the inner AdaptiveCache for advanced operations
Sourcepub async fn get_adaptive_metrics(&self) -> AdaptiveCacheMetrics
pub async fn get_adaptive_metrics(&self) -> AdaptiveCacheMetrics
Get adaptive-specific metrics
Sourcepub async fn cold_count(&self) -> usize
pub async fn cold_count(&self) -> usize
Get the number of cold items
Trait Implementations§
Source§impl Cache for AdaptiveCacheAdapter
impl Cache for AdaptiveCacheAdapter
Source§fn record_access<'life0, 'async_trait>(
&'life0 self,
id: Uuid,
hit: bool,
_size_bytes: Option<usize>,
) -> Pin<Box<dyn Future<Output = bool> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn record_access<'life0, 'async_trait>(
&'life0 self,
id: Uuid,
hit: bool,
_size_bytes: Option<usize>,
) -> Pin<Box<dyn Future<Output = bool> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Record a cache access (hit or miss) Read more
Source§fn remove<'life0, 'async_trait>(
&'life0 self,
id: Uuid,
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn remove<'life0, 'async_trait>(
&'life0 self,
id: Uuid,
) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Remove an entry from the cache
Source§fn contains<'life0, 'async_trait>(
&'life0 self,
id: Uuid,
) -> Pin<Box<dyn Future<Output = bool> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn contains<'life0, 'async_trait>(
&'life0 self,
id: Uuid,
) -> Pin<Box<dyn Future<Output = bool> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Check if an entry exists and is not expired
Source§fn get_metrics<'life0, 'async_trait>(
&'life0 self,
) -> Pin<Box<dyn Future<Output = CacheMetrics> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_metrics<'life0, 'async_trait>(
&'life0 self,
) -> Pin<Box<dyn Future<Output = CacheMetrics> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Get current cache metrics
Source§impl From<AdaptiveCacheConfig> for AdaptiveCacheAdapter
impl From<AdaptiveCacheConfig> for AdaptiveCacheAdapter
Source§fn from(config: AdaptiveCacheConfig) -> Self
fn from(config: AdaptiveCacheConfig) -> Self
Converts to this type from the input type.
Auto Trait Implementations§
impl Freeze for AdaptiveCacheAdapter
impl !RefUnwindSafe for AdaptiveCacheAdapter
impl Send for AdaptiveCacheAdapter
impl Sync for AdaptiveCacheAdapter
impl Unpin for AdaptiveCacheAdapter
impl UnsafeUnpin for AdaptiveCacheAdapter
impl !UnwindSafe for AdaptiveCacheAdapter
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
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> 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 moreSource§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.