mongo-lock-async

Crates.iomongo-lock-async
lib.rsmongo-lock-async
version0.4.0
sourcesrc
created_at2023-01-09 21:07:50.691738
updated_at2024-07-04 22:30:58.166677
descriptionDistributed mutex locks with MongoDB
homepage
repositoryhttps://github.com/lazureykis/mongo-lock-async
max_upload_size
id754787
size11,808
Pavel Lazureykis (lazureykis)

documentation

https://docs.rs/mongo-lock-async

README

Distributed mutually exclusive locks in MongoDB.

Crates.io docs.rs

This crate contains only async implementation. If you need a synchronous version, use mongo-lock crate.

This implementation relies on system time. Ensure that NTP clients on your servers are configured properly.

Installation

Add this crate to Cargo.toml

[dependencies]
mongo_lock_async = "0"

Usage

#[tokio::main]
async fn main() {
    let mongo = mongodb::Client::with_uri_str("mongodb://localhost").await.unwrap();

    // We need to ensure that mongodb collection has a proper index.
    mongo_lock_async::prepare_database(&mongo).await.unwrap();

    if let Ok(Some(lock)) =
        mongo_lock_async::Lock::try_acquire(
            &mongo,
            "my-key",
            std::time::Duration::from_secs(30)
        ).await
    {
        println!("Lock acquired.");

        // Release the lock before ttl expires to allow others to acquire it.
        lock.release().await.ok();
    }
}
Commit count: 11

cargo fmt