You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

99 lines
2.0 KiB
Markdown

6 years ago
# gum
Go Unit Manager is a simple Goroutine unit manager for GoLang.
Features:
- Scheduling of multiple goroutines.
6 years ago
- Shutdown on `os.Signal` events.
6 years ago
- Gracefull shutdown of units
## Overview
1 year ago
A unit is a type that implements `WorkUnit` interface. The `Run()` method
6 years ago
of each registered unit is spawned in its own goroutine.
6 years ago
The `Manager` handles communication and synchronized shutdown procedure.
## Usage
1. Create a unit manager
2. Implement the `WorkUnit` on your goroutines
3. Add units to the manager
6 years ago
4. Run the manager and wait on its `Quit` channel
6 years ago
```golang
import (
"os"
"log"
"time"
6 years ago
gum "git.sp4ke.com/sp4ke/gum.git"
6 years ago
)
type Worker struct{}
// Example loop, will be spwaned inside a goroutine
1 year ago
func (w *Worker) Run(um UnitManager) {
6 years ago
ticker := time.NewTicker(time.Second)
6 years ago
// Worker's loop
6 years ago
for {
select {
case <-ticker.C:
log.Println("tick")
6 years ago
// Read from channel if this worker unit should stop
6 years ago
case <-um.ShouldStop():
6 years ago
// Shutdown work for current unit
6 years ago
w.Shutdown()
6 years ago
// Notify manager that this unit is done.
6 years ago
um.Done()
}
}
6 years ago
}
func (w *Worker) Shutdown() {
1 year ago
// shutdown procedure for worker
6 years ago
return
}
func NewWorker() *Worker {
return &Worker{}
}
func main() {
// Create a unit manager
manager := gum.NewManager()
6 years ago
// Shutdown all units on SIGINT
manager.ShutdownOn(os.Interrupt)
6 years ago
// NewWorker returns a type implementing WorkUnit interface unit :=
worker := NewWorker()
worker2 := NewWorker()
6 years ago
// Register the unit with the manager
1 year ago
manager.AddUnit(worker, "work1")
manager.AddUnit(worker2, "work2")
6 years ago
6 years ago
// Run the manager
go manager.Run()
6 years ago
// Wait for all units to shutdown gracefully through their `Shutdown` method
<-manager.Quit
}
```
## Issues and Comments
6 years ago
This repo is a mirror. For any question or issues use the repo hosted at
[https://git.sp4ke.com/sp4ke/gum.git](https://git.sp4ke.com/sp4ke/gum.git)
6 years ago