Crate ncryptf::deadpool_redis
Expand description
Deadpool for Redis

Deadpool is a dead simple async pool for connections and objects of any type.
This crate implements a deadpool
manager for redis.
Features
| Feature | Description | Extra dependencies | Default |
|---|---|---|---|
rt_tokio_1 | Enable support for tokio crate | deadpool/rt_tokio_1, redis/tokio-comp | yes |
rt_async-std_1 | Enable support for async-std crate | deadpool/rt_async-std_1, redis/async-std-comp | no |
serde | Enable support for serde crate | deadpool/serde, serde/derive | no |
Example
use deadpool_redis::{redis::{cmd, FromRedisValue}, Config, Runtime};
#[tokio::main]
async fn main() {
let mut cfg = Config::from_url("redis://127.0.0.1/");
let pool = cfg.create_pool(Some(Runtime::Tokio1)).unwrap();
{
let mut conn = pool.get().await.unwrap();
cmd("SET")
.arg(&["deadpool/test_key", "42"])
.query_async::<_, ()>(&mut conn)
.await.unwrap();
}
{
let mut conn = pool.get().await.unwrap();
let value: String = cmd("GET")
.arg(&["deadpool/test_key"])
.query_async(&mut conn)
.await.unwrap();
assert_eq!(value, "42".to_string());
}
}Example with config and dotenv crate
use deadpool_redis::{redis::{cmd, FromRedisValue}, Runtime};
use dotenv::dotenv;
#[derive(Debug, serde::Deserialize)]
struct Config {
#[serde(default)]
redis: deadpool_redis::Config
}
impl Config {
pub fn from_env() -> Result<Self, config::ConfigError> {
config::Config::builder()
.add_source(config::Environment::default().separator("__"))
.build()?
.try_deserialize()
}
}
#[tokio::main]
async fn main() {
dotenv().ok();
let cfg = Config::from_env().unwrap();
let pool = cfg.redis.create_pool(Some(Runtime::Tokio1)).unwrap();
{
let mut conn = pool.get().await.unwrap();
cmd("SET")
.arg(&["deadpool/test_key", "42"])
.query_async::<_, ()>(&mut conn)
.await.unwrap();
}
{
let mut conn = pool.get().await.unwrap();
let value: String = cmd("GET")
.arg(&["deadpool/test_key"])
.query_async(&mut conn)
.await.unwrap();
assert_eq!(value, "42".to_string());
}
}FAQ
-
How can I enable features of the
rediscrate?Make sure that you depend on the same version of
redisasdeadpool-redisdoes and enable the needed features in your ownCrate.tomlfile:[dependencies] deadpool-redis = { version = "0.9", features = ["serde"] } redis = { version = "0.21", default-features = false, features = ["tls"] }
License
Licensed under either of
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Modules
- redis-rs is a Rust implementation of a Redis client library. It exposes a general purpose interface to Redis and also provides specific helpers for commonly used functionality.
Structs
- Configuration object.
- Wrapper around
redis::aio::Connection. - This is a 1:1 copy of the
redis::ConnectionInfostruct. This is duplicated here in order to add support for the [serde::Deserialize] trait which is required for the [serde] support. - Statistics regarding an object returned by the pool
Poolconfiguration.- This is a 1:1 copy of the
redis::RedisConnectionInfostruct. This is duplicated here in order to add support for the [serde::Deserialize] trait which is required for the [serde] support. - The current pool status.
Enums
- This error is returned if the configuration contains an error
- This is a 1:1 copy of the
redis::ConnectionAddrenumeration. This is duplicated here in order to add support for the [serde::Deserialize] trait which is required for the [serde] support. - Enumeration for picking a runtime implementation.
Type Aliases
- Type alias for using [
deadpool::managed::BuildError] withredis. - Type alias for using [
deadpool::managed::CreatePoolError] withredis. - Type alias for using [
deadpool::managed::Hook] withredis. - Type alias for using [
deadpool::managed::HookError] withredis. - Type alias for using [
deadpool::managed::HookErrorCause] withredis. - Type alias for using [
deadpool::managed::Object] withredis. - Type alias for using [
deadpool::managed::Pool] withredis. - Type alias for using [
deadpool::managed::PoolBuilder] withredis. - Type alias for using [
deadpool::managed::PoolError] withredis.