Skip to content

sizeofint/reddistlock

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

RedDistLock

Redis Distributed Lock - implemented via Redis PubSub and Lists

Example

package main

import (
	"context"
	"github.com/go-redis/redis/v8"
	"github.com/sizeofint/reddistlock"
	"log"
)

var redDistLock reddistlock.RedDistLock

func main() {
    redDistLock = reddistlock.New(redis.NewClient(&redis.Options{
        Addr:     "127.0.0.1:6379",
        Password: "",
        DB:       0,
    }))
    
    testExclusiveDistributedExecution(context.Background())
}

func testExclusiveDistributedExecution(ctx context.Context) {
    lk, err := redDistLock.Lock(ctx, "unique-lock-key", 5)
    if err != nil {
        log.Fatalln(err)
    }
    defer lk.Unlock(ctx)
    /**
    Do some exclusive work here
    */
}

Please also check out examples folder

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages