An asynchronous Redis client for Rust.
Documentation
Philosophy
- Low allocations
- Full async library
- Lock free implementation
- Rust idiomatic API
- Multiplexing as a core feature
Features
- Full documentation with multiple examples
- Support all Redis Commands until Redis 7.0
- Async support (tokio or async-std)
- Different client modes:
- Single client
- Multiplexed client
- Pooled client manager (based on bb8)
- Automatic command batching
- Advanced reconnection & retry strategy
- Pipelining support
- Configuration with Redis URL or dedicated builder
- TLS support
- Transaction support
- Pub/sub support
- Sentinel support
- LUA Scripts/Functions support
- Cluster support (minimus supported Redis version is 6)
- Redis Stack support:
- RedisJSON v2.4 support
- RedisSearch v2.6 support
- RedisGraph v2.10 support
- RedisBloom v2.4 support
- RedisTimeSeries v1.8 support
Basic Usage
use ;
async
Tests
- From the
redis
directory, rundocker_up.sh
ordocker_up.cmd
- run
cargo test --features pool,redis-stack,tokio-tls
(Tokio runtime) - run
cargo test --no-default-features --features redis-stack,async-std-runtime,async-std-tls
(async-std runtime)
Benchmarks
- From the
redis
directory, rundocker_up.sh
ordocker_up.cmd
- run
cargo bench