/k8slock

A distributed locking module for Go using the Lease resource from the Kubernetes coordination API

Primary LanguageGoMIT LicenseMIT

k8slock Godoc Go Report Card

k8slock is a Go module that makes it easy to do distributed locking by implementing the sync.Locker interface using the Lease resource from the Kubernetes coordination API.

If you want to use Kubernetes to create a simple distributed lock, this module is for you.

Basic Usage

package main

import "github.com/jrhouston/k8slock"

func main() {
    locker, err := k8slock.NewLocker("example-lock")
    if err != nil {
        panic(err)
    }

    locker.Lock()
    // do some work
    locker.Unlock()
}

Locker Options

The locker can be configured using the following functional options:

Option Details
TTL(duration) The duration until the lock expires and can be forcibly claimed. By default the lock can be held infinitely.
RetryWaitDuration(duration) The duration to wait before retrying after failing to acquired the lock. Default: 1 second.
InClusterConfig() Get the kubernetes client config from inside a pod. Defaults to a clientset using the local kubeconfig.
Clientset(*kubernetes.Clientset) Configure a custom Kubernetes Clientset. Defaults to a clientset using the local kubeconfig.
Namespace(string) The kubernetes namespace to store the Lease resource. Defaults to "default".
ClientID(string) A unique ID for the client that is trying to obtain the lock. Defaults to a random UUID.

e.g:

locker, err := k8slock.NewLocker("example-lock", k8slock.Namespace("locks"), k8slock.ClientID("client-0"))