Merge remote-tracking branch 'upstream/v2' into v2
This commit is contained in:
@@ -0,0 +1,73 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"log"
|
||||
"time"
|
||||
|
||||
"github.com/andoma-go/gocron/v2"
|
||||
)
|
||||
|
||||
var _ gocron.Elector = (*myElector)(nil)
|
||||
|
||||
type myElector struct {
|
||||
num int
|
||||
leader bool
|
||||
}
|
||||
|
||||
func (m myElector) IsLeader(_ context.Context) error {
|
||||
if m.leader {
|
||||
log.Printf("node %d is leader", m.num)
|
||||
return nil
|
||||
}
|
||||
log.Printf("node %d is not leader", m.num)
|
||||
return fmt.Errorf("not leader")
|
||||
}
|
||||
|
||||
func main() {
|
||||
log.SetFlags(log.LstdFlags | log.Lmicroseconds)
|
||||
|
||||
for i := 0; i < 3; i++ {
|
||||
go func(i int) {
|
||||
elector := &myElector{
|
||||
num: i,
|
||||
}
|
||||
if i == 0 {
|
||||
elector.leader = true
|
||||
}
|
||||
|
||||
scheduler, err := gocron.NewScheduler(
|
||||
gocron.WithDistributedElector(elector),
|
||||
)
|
||||
if err != nil {
|
||||
log.Println(err)
|
||||
return
|
||||
}
|
||||
|
||||
_, err = scheduler.NewJob(
|
||||
gocron.DurationJob(time.Second),
|
||||
gocron.NewTask(func() {
|
||||
log.Println("run job")
|
||||
}),
|
||||
)
|
||||
|
||||
if err != nil {
|
||||
log.Println(err)
|
||||
return
|
||||
}
|
||||
scheduler.Start()
|
||||
|
||||
if i == 0 {
|
||||
time.Sleep(5 * time.Second)
|
||||
elector.leader = false
|
||||
}
|
||||
if i == 1 {
|
||||
time.Sleep(5 * time.Second)
|
||||
elector.leader = true
|
||||
}
|
||||
}(i)
|
||||
}
|
||||
|
||||
select {} // wait forever
|
||||
}
|
||||
Reference in New Issue
Block a user