RedisCache

Struct RedisCache 

Source
pub struct RedisCache { /* private fields */ }
Expand description

Redis distributed cache with ConnectionManager for automatic reconnection

This is the default L2 (warm tier) cache backend, providing:

  • Distributed caching across multiple instances
  • Persistence to disk
  • Automatic reconnection via ConnectionManager
  • TTL introspection for cache promotion
  • Pattern-based key scanning

Implementations§

Source§

impl RedisCache

Source

pub async fn new() -> Result<Self>

Create new Redis cache with ConnectionManager for automatic reconnection

§Errors

Returns an error if the Redis client cannot be created or connection fails.

Source

pub async fn with_url(redis_url: &str) -> Result<Self>

Create new Redis cache with custom URL

§Arguments
  • redis_url - Redis connection string (e.g., <redis://localhost:6379>)
§Errors

Returns an error if the Redis client cannot be created or connection fails.

Source

pub async fn scan_keys(&self, pattern: &str) -> Result<Vec<String>>

Scan keys matching a pattern (glob-style: *, ?, [])

Uses Redis SCAN command (non-blocking, cursor-based iteration) This is safe for production use, unlike KEYS command.

§Arguments
  • pattern - Glob-style pattern (e.g., “user:”, “product:123:”)
§Returns

Vector of matching key names

§Examples
// Find all user cache keys
let keys = cache.scan_keys("user:*").await?;

// Find specific user's cache keys
let keys = cache.scan_keys("user:123:*").await?;
§Errors

Returns an error if the Redis command fails.

Source

pub async fn remove_bulk(&self, keys: &[String]) -> Result<usize>

Remove multiple keys at once (bulk delete)

More efficient than calling remove() multiple times

§Errors

Returns an error if the Redis command fails.

Trait Implementations§

Source§

impl CacheBackend for RedisCache

Implement CacheBackend trait for RedisCache

This allows RedisCache to be used as a pluggable backend in the multi-tier cache system.

Source§

fn get<'life0, 'life1, 'async_trait>( &'life0 self, key: &'life1 str, ) -> Pin<Box<dyn Future<Output = Option<Value>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Get value from cache by key Read more
Source§

fn set_with_ttl<'life0, 'life1, 'async_trait>( &'life0 self, key: &'life1 str, value: Value, ttl: Duration, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Set value in cache with time-to-live Read more
Source§

fn remove<'life0, 'life1, 'async_trait>( &'life0 self, key: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Remove value from cache Read more
Source§

fn health_check<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = bool> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Check if cache backend is healthy Read more
Source§

fn name(&self) -> &'static str

Get the name of this cache backend Read more
Source§

impl L2CacheBackend for RedisCache

Implement L2CacheBackend trait for RedisCache

This extends CacheBackend with TTL introspection capabilities needed for L2->L1 promotion.

Source§

fn get_with_ttl<'life0, 'life1, 'async_trait>( &'life0 self, key: &'life1 str, ) -> Pin<Box<dyn Future<Output = Option<(Value, Option<Duration>)>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Get value with its remaining TTL from L2 cache Read more

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more