#kubernetes #election #leader #lease #workload #lock #leader-election

kube-leader-election

Leader election implementations for Kubernetes workloads

36 breaking releases

new 0.39.0 Jan 13, 2025
0.38.0 Nov 20, 2024
0.37.0 Oct 11, 2024
0.34.0 Jul 23, 2024
0.1.2 Jul 26, 2021

#274 in Concurrency

Download history 827/week @ 2024-09-26 506/week @ 2024-10-03 679/week @ 2024-10-10 658/week @ 2024-10-17 380/week @ 2024-10-24 425/week @ 2024-10-31 446/week @ 2024-11-07 575/week @ 2024-11-14 1019/week @ 2024-11-21 1328/week @ 2024-11-28 1343/week @ 2024-12-05 1163/week @ 2024-12-12 929/week @ 2024-12-19 902/week @ 2024-12-26 718/week @ 2025-01-02 1520/week @ 2025-01-09

4,271 downloads per month

MIT license

23KB
274 lines

Kubernetes Leader Election in Rust

CI workflow crates.io version License: MIT

This library provides simple leader election for Kubernetes workloads.

[dependencies]
kube-leader-election = "0.39.0"

Example

Acquire leadership on a Kubernetes Lease called some-operator-lock, in the default namespace and promise to renew the lock every 15 seconds:

let leadership = LeaseLock::new(
    kube::Client::try_default().await?,
    "default",
    LeaseLockParams {
        holder_id: "some-operator".into(),
        lease_name: "some-operator-lock".into(),
        lease_ttl: Duration::from_secs(15),
    },
);

// Run this in a background task every 5 seconds
// Share the result with the rest of your application; for example using Arc<AtomicBool>
// See https://github.com/hendrikmaus/kube-leader-election/blob/master/examples/shared-lease.rs
let lease = leadership.try_acquire_or_renew().await?;

log::info!("currently leading: {}", lease.acquired_lease);

Please refer to the examples for runnable usage demonstrations.

Features

Kubernetes Lease Locking

A very basic form of leader election without fencing, i.e., only use this if your application can tolerate multiple replicas acting as leader for a short amount of time.

This implementation uses a Kubernetes Lease resource from the API group coordination.k8s.io, which is locked and continuously renewed by the leading replica. The leaseholder, as well as all candidates, use timestamps to determine if a lease can be acquired. Therefore, this implementation is volatile to datetime skew within a cluster.

Only use this implementation if you are aware of its downsides, and your workload can tolerate them.

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

License

MIT

Dependencies

~56MB
~857K SLoC