Hitbox is an asynchronous caching framework supporting multiple backends and suitable for distributed and for single-machine applications.
- Actix
- Actix-Web
- Automatic cache key generation.
- Multiple cache backend implementations:
- Stale cache mechanics.
- Cache locks for dogpile effect preventions.
- Distributed cache locks.
- Detailed metrics out of the box.
- Redis
- In-memory backend
- derive - Support for Cacheable trait derive macros.
- metrics - Support for metrics.
Default cache key implementation based on serde_qs crate and have some restrictions.
Dependencies:
[dependencies]
hitbox = "0.1"
Code:
First, you should derive Cacheable trait for your struct or enum:
use hitbox::prelude::*;
use serde::{Deserialize, Serialize};
#[derive(Cacheable, Serialize)] // With features=["derive"]
struct Ping {
id: i32,
}
Or implement that trait manually:
use hitbox::{Cacheable, CacheError};
struct Ping { id: i32 }
impl Cacheable for Ping {
fn cache_key(&self) -> Result<String, CacheError> {
Ok(format!("{}::{}", self.cache_key_prefix(), self.id))
}
fn cache_key_prefix(&self) -> String { "Ping".to_owned() }
}