redis_pool 0.1.0

Library to Provide a redis client and cluster client pools.
Documentation
<h1 align="center">
    RedisPool
</h1>
<div align="center">
    Library to Provide an <a href="https://github.com/redis-rs/redis-rs/tree/main">Redis</a> pool.
</div>
<br />
<div align="center">
    <a href="https://crates.io/crates/redis_pool"><img src="https://img.shields.io/crates/v/redis_pool?style=plastic" alt="crates.io"></a>
    <a href="https://docs.rs/redis_pool"><img src="https://docs.rs/redis_pool/badge.svg" alt="docs.rs"></a>
    <img src="https://img.shields.io/badge/min%20rust-1.60-green.svg" alt="Minimum Rust Version">
</div>

## License


This project is licensed under either [Apache License, Version 2.0](LICENSE-APACHE), [zlib License](LICENSE-ZLIB), or [MIT License](LICENSE-MIT), at your option.

## Help


If you need help with this library or have suggestions please go to our [Discord Group](https://discord.gg/gVXNDwpS3Z)

## Install


RedisPool uses [`tokio`] runtime.

[`tokio`]: https://github.com/tokio-rs/tokio

```toml
# Cargo.toml

[dependencies]
redis_pool = "0.1.0"
```

#### Cargo Feature Flags

`axum`: Enables axum FromRequestParts to retrieve from State.
`json`: Enabled serde's json for Redis.
`cluster`: Enabled Redis Cluster Client and connections.

# Example


```rust no_run
use redis_pool::{RedisConnectionManager};
use axum::{
    Router,
    routing::get,
};
use std::time::Duration;

#[tokio::main]

async fn main() {
    let redis_url = "redis://default:YourSecretPassWord@127.0.0.1:6379/0";
    let client = redis::Client::open(redis_url).expect("Error while testing the connection");
    let manager = RedisConnectionManager::new(client, 5);

    // build our application with some routes
    let app = Router::with_state(manager)
        .route("/drop", get(drop_table));

    // run it
    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
    tracing::debug!("listening on {}", addr);
    axum::Server::bind(&addr)
        .serve(app.into_make_service())
        .await
        .unwrap();
}

async fn test_pool(manager: RedisConnectionManager) -> String {
    let mut connection = manager.aquire().await.unwrap();
    redis::pipe()
            .set(0, "Hello")
            .ignore()
            .query_async(&mut connection)
            .await.unwrap();

    redis::cmd("GET").arg(0).query_async(&mut connection).await.unwrap()
}
```