Crates.io | redis-async-pool |
lib.rs | redis-async-pool |
version | 0.2.4 |
source | src |
created_at | 2020-11-28 11:43:41.512571 |
updated_at | 2020-12-01 15:55:36.159031 |
description | Deadpool manager for asynchronous Redis connections |
homepage | |
repository | https://github.com/zenria/redis-async-pool |
max_upload_size | |
id | 317418 |
size | 52,119 |
redis-async-pool
implements a deadpool manager for asynchronous
connections of the redis crate. Connections returned by the pool can be used as regular redis::aio::Connection
.
You may not need of a pool of async connections to Redis. Depending on your
workload, a multiplexed connection will be way faster. Using the ConnectionManager
provided by the redis crate, you can achieve very high performances without pooling
connections.
use redis::AsyncCommands;
use redis_async_pool::{RedisConnectionManager, RedisPool};
// Create a pool of maximum 5 connections, checked on reuse without ttl.
let pool = RedisPool::new(
RedisConnectionManager::new(redis::Client::open("redis://localhost:6379")?, true, None),
5,
);
// get a connection with the get() async method and use it as regular redis connection
let mut con = pool.get().await?;
con.set(b"key", b"value").await?;
let value: Vec<u8> = con.get(b"key").await?;
assert_eq!(value, b"value");
You can set a ttl for each created connection by the pool, this helps avoiding huge memory consumption when keeping many connections open during a too long time.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.