The goal of this crate is to provide a thread-safe and easy way to access any data structure which might is stored in a database at most once and keep it in cache for further requests.
This library is based on tokio-rs and futures.
Using this library is as easy as that: ```rust
async fn main() {
let staticdb: HashMap
let (cache, _) = LoadingCache::new(move |key: String| {
let db_clone = static_db.clone();
async move {
db_clone.get(&key).cloned()
}
});
let result = cache.get("foo".to_owned()).await.unwrap();
assert_eq!(result, 32);
} ```
The LoadingCache will first try to look up the result in an internal HashMap and if it's not found and there's no load ongoing, it will fire the load request and queue any other get requests until the load request finishes.
You can use a simple pre-built LRU cache from the lru-rs crate by enabling
the lru-cache
feature.
To create a LoadingCache with lru cache backing use the with_backing
method on the LoadingCache.
rust
async fn main() {
let size: usize = 10;
let (cache, _) = LoadingCache::with_backing(LruCacheBacking::new(size), move |key: String| {
async move {
Some(key.to_lowercase())
}
});
}
To implement an own cache backing, simply implement the public CacheBacking
trait from the backing
mod.
rust
pub trait CacheBacking<K, V>
where K: Eq + Hash + Sized + Clone + Send,
V: Sized + Clone + Send {
fn get(&mut self, key: &K) -> Option<&V>;
fn set(&mut self, key: K, value: V) -> Option<V>;
fn remove(&mut self, key: &K) -> Option<V>;
fn contains_key(&self, key: &K) -> bool;
}