redsync

Crates.ioredsync
lib.rsredsync
version1.0.1
sourcesrc
created_at2021-03-01 07:03:01.882074
updated_at2023-04-18 20:01:59.701222
descriptionA Rust implementation of Redlock for distributed locks with Redis
homepagehttps://github.com/jace-ys/redsync
repositoryhttps://github.com/jace-ys/redsync
max_upload_size
id362098
size37,150
Jace Tan (jace-ys)

documentation

README

crates.io docs.rs ci release

Redsync

A Rust implementation of Redlock for distributed locks with Redis.

Installation

Add the following line to your Cargo.toml file:

[dependencies]
redsync = "1.0.1"

Documentation

See https://docs.rs/redsync.

Quick Start

use std::error::Error;
use std::time::Duration;
use redsync::{RedisInstance, Redsync};

fn main() -> Result<(), Box<dyn Error>> {
  let dlm = Redsync::new(vec![
    RedisInstance::new("redis://127.0.0.1:6389")?,
    RedisInstance::new("redis://127.0.0.1:6399")?,
    RedisInstance::new("redis://127.0.0.1:6379")?,
  ]);

  let lock = dlm.lock("resource", Duration::from_secs(1))?;
  dlm.unlock(&lock)?;

  Ok(())
}

For more examples, see examples.

Commit count: 20

cargo fmt