Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/flowerinthenight/kettle
A simple library to share workloads to a group of workers with one leader at any time. Built on top of Redis.
https://github.com/flowerinthenight/kettle
distributed-locking go golang redis
Last synced: 2 months ago
JSON representation
A simple library to share workloads to a group of workers with one leader at any time. Built on top of Redis.
- Host: GitHub
- URL: https://github.com/flowerinthenight/kettle
- Owner: flowerinthenight
- License: mit
- Created: 2019-06-04T03:18:58.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-08-22T04:30:44.000Z (over 1 year ago)
- Last Synced: 2024-06-20T17:43:21.895Z (7 months ago)
- Topics: distributed-locking, go, golang, redis
- Language: Go
- Homepage:
- Size: 4.15 MB
- Stars: 14
- Watchers: 3
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![Go](https://github.com/flowerinthenight/kettle/actions/workflows/main.yml/badge.svg)](https://github.com/flowerinthenight/kettle/actions/workflows/main.yml)
[![Go Reference](https://pkg.go.dev/badge/github.com/flowerinthenight/kettle.svg)](https://pkg.go.dev/github.com/flowerinthenight/kettle)## Overview
`kettle` is a simple library that abstracts the use of distributed locking to elect a master among group of workers at a specified time interval. The elected master will then call the "master" function. This library uses [Redis](https://redis.io/) as the default [distributed locker](https://redis.io/topics/distlock).## How it works
All workers that share the same name will attempt to grab a Redis lock to become the master. A provided master function will be executed by the node that successfully grabbed the lock. A single node works as well, in which case, that node will run both as master and a worker.The main changes in v2.x.x is the use of context for termination and an optional 'done' channel for notification. It looks something like this:
```go
name := "kettle-example"
k, _ := kettle.New(kettle.WithName(name), kettle.WithVerbose(true))
in := kettle.StartInput{
// Our master callback function.
Master: func(v interface{}) error {
kt := v.(*kettle.Kettle)
log.Println("from master, name:", kt.Name())
return nil
},
MasterCtx: k, // arbitrary data that is passed to master function
}ctx, cancel := context.WithCancel(context.TODO())
done := make(chan error, 1)
err = k.Start(ctx, &in, done)
_ = err// Simulate work
time.Sleep(time.Second * 5)
cancel() // terminate
<-done // wait
```For version 0.x.x, it looks something like this:
```go
name := "kettle-example"
k, _ := kettle.New(kettle.WithName(name), kettle.WithVerbose(true))
in := kettle.StartInput{
// Our master callback function.
Master: func(v interface{}) error {
kt := v.(*kettle.Kettle)
log.Println("from master, name:", kt.Name())
return nil
},
MasterCtx: k, // arbitrary data that is passed to master function
Quit: make(chan error),
Done: make(chan error),
}err = k.Start(&in)
_ = err// Simulate work
time.Sleep(time.Second * 5)
in.Quit <- nil // terminate
<-in.Done // wait
```## Environment variables
```bash
# Required
REDIS_HOST=1.2.3.4:6379# Optional
REDIS_PASSWORD=***
REDIS_TIMEOUT_SECONDS=5
```## Example
A simple example is provided [here](https://github.com/flowerinthenight/kettle/blob/master/examples/v2/simple/main.go) for reference. Try running it simultaneously on multiple nodes. For the version 0.x.x example, check it out [here](https://github.com/flowerinthenight/kettle/blob/master/examples/simple/main.go).