Skip to content

Redis cluster support for the `r2d2` connection pool.

Notifications You must be signed in to change notification settings

alu/r2d2-redis-cluster

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 

Repository files navigation

MIT licensed

Redis cluster support for the r2d2 connection pool.

Documentation is available at here.

Example

extern crate r2d2;
extern crate r2d2_redis_cluster;

use std::thread;

use r2d2::Pool;
use r2d2_redis_cluster::{Commands, RedisClusterConnectionManager};

fn main() {
    let redis_uri = vec!["redis:https://127.0.0.1:6379", "redis:https://127.0.0.1:6378", "redis:https://127.0.0.1:6377"];
    let manager = RedisClusterConnectionManager::new(redis_uri).unwrap();
    let pool = Pool::builder()
        .build(manager)
        .unwrap();

    let mut handles = Vec::new();

    for _ in 0..10 {
        let pool = pool.clone();
        handles.push(thread::spawn(move || {
            let connection = pool.get().unwrap();
            let n: u64 = connection.incr("test", 1).unwrap();
        }));
    }

    for h in handles {
        h.join().unwrap();
    }

    let connection = pool.get().unwrap();
    let res: u64 = connection.get("test").unwrap();

    assert_eq!(res, 10);
}

About

Redis cluster support for the `r2d2` connection pool.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 100.0%