Skip to content

Latest commit

 

History

History
64 lines (49 loc) · 1.82 KB

README.md

File metadata and controls

64 lines (49 loc) · 1.82 KB

Go Etcd Cron

Work-in-progress

GoDoc

Goal

This package aims at implementing a distributed and fault tolerant cron in order to:

  • Run an identical process on several hosts
  • Each of these process instantiate a subset of the cron jobs
  • Ensure only one of these processes executes a job
  • Number of cron jobs can scale by increasing the number of hosts
  • Eventualy, a trigger can be missed due to change in leadership for a cron job

Etcd Initialization

By default the library creates an etcd client on 127.0.0.1:2379

c, _ := etcdcron.NewEtcdMutexBuilder(clientv3.Config{
  Endpoints: []string{"etcd-host1:2379", "etcd-host2:2379"},
})
cron, _ := etcdcron.New(WithEtcdMutexBuilder(c))
cron.AddJob(Job{
  Name: "job0",
  Rhythm: "*/2 * * * * *",
  Func: func(ctx context.Context) error {
    // Handler
  },
})

Error Handling

errorsHandler := func(ctx context.Context, job etcdcron.Job, err error) {
  // Do something with the error which happened during 'job'
}
etcdErrorsHandler := func(ctx context.Context, job etcdcron.Job, err error) {
  // Do something with the error which happened at the time of the execution of 'job'
  // But locking mecanism fails because of etcd error
}

cron, _ := etcdcron.New(
  WithErrorsHandler(errorsHandler),
  WithEtcdErrorsHandler(etcdErrorsHandler),
)

cron.AddJob(Job{
  Name: "job0",
  Rhythm: "*/2 * * * * *",
  Func: func(ctx context.Context) error {
    // Handler
  },
})

History

This is a fork of https://github.com/Scalingo/go-etcd-cron, which had been based on https://github.com/robfig/cron.

This fork has similar but still different goals from Scalingo's go-etcd-cron library.