CrudeCache
is a simple utility for good enough concurrent caching needs. Inspired by Play Framework's cache.getOrElseUpdate.
rust
//Returns non-expired cached item. If one does not exist, new item will be cached & returned
cache.get_or_else_update("cache_key", Duration::from_secs(60), async_function).await
Disclaimer: Please note that CrudeCache
was developed primarily for personal projects and has not been battle-tested in large-scale production environments. Plus I am still new to Rust, so contributions, suggestions, and feedback are more than welcome.
Expiration of cached item is evaluated lazily.
Uses tokio::sync::RwLock
for async locking.
Items are stored in a ShardedMap
, which splits the data across multiple shards (HashMaps
). This aims to minimize contention points.
Add this to your Cargo.toml
:
toml
[dependencies]
crude_cache = "0.1.0"
```rust use crude_cache::CrudeCache;
pub struct DataService {
cache: Arc
impl DataService { pub async fn getbigdata(&self) -> SomeBigType { self.cache.getorelseupdate("bigdata", Duration::fromsecs(60), || self.db.bigdata()).await }
pub async fn get_other_data(&self) -> OtherType {
self.cache.get_or_else_update("other_data", Duration::from_secs(60), || self.db.other_data()).await
}
} ```