Skip to content

Latest commit

 

History

History
219 lines (165 loc) · 4.59 KB

README.md

File metadata and controls

219 lines (165 loc) · 4.59 KB

gron

Build Status Go Report Card GoDoc

Gron provides a clear syntax for writing and deploying cron jobs.

This is a fork repo of github.com/roylee0704/gron.

Just add feature of canceling job.

Goals

  • Minimalist APIs for scheduling jobs.
  • Thread safety.
  • Customizable Job Type.
  • Customizable Schedule.

Installation

# $ go get github.com/roylee0704/gron
$ go get github.com/fakeyanss/gron

Usage

Create schedule.go

package main

import (
	"fmt"
	"time"
	// "github.com/roylee0704/gron"
	"github.com/fakeyanss/gron"
)

func main() {
	c := gron.New()
	c.AddFunc(gron.Every(1*time.Hour), func() {
		fmt.Println("runs every hour.")
	})
	c.Start()
}

Schedule Parameters

All scheduling is done in the machine's local time zone (as provided by the Go time package).

Setup basic periodic schedule with gron.Every().

gron.Every(1*time.Second)
gron.Every(1*time.Minute)
gron.Every(1*time.Hour)

Also support Day, Week by importing gron/xtime:

// import "github.com/roylee0704/gron/xtime"
import "github.com/fakeyanss/gron/xtime"

gron.Every(1 * xtime.Day)
gron.Every(1 * xtime.Week)

Schedule to run at specific time with .At(hh:mm)

gron.Every(30 * xtime.Day).At("00:00")
gron.Every(1 * xtime.Week).At("23:59")

Custom Job Type

You may define custom job types by implementing gron.Job interface: Run().

For example:

type Reminder struct {
	Msg string
}

func (r Reminder) Run() {
  fmt.Println(r.Msg)
}

After job has defined, instantiate it and schedule to run in Gron.

c := gron.New()
r := Reminder{ "Feed the baby!" }
c.Add(gron.Every(8*time.Hour), r)
c.Start()

Custom Job Func

You may register Funcs to be executed on a given schedule. Gron will run them in their own goroutines, asynchronously.

c := gron.New()
c.AddFunc(gron.Every(1*time.Second), func() {
	fmt.Println("runs every second")
})
c.Start()

Custom Schedule

Schedule is the interface that wraps the basic Next method: Next(p time.Duration) time.Time

In gron, the interface value Schedule has the following concrete types:

  • periodicSchedule. adds time instant t to underlying period p.
  • atSchedule. reoccurs every period p, at time components(hh:mm).

For more info, checkout schedule.go.

Cancel Job

You may cancel specified job with a unique jobID.

type canceledJob struct { // implements of JobWithCancel interface
	id string
}

func (j *canceledJob) JobID() string {
	return id
}

func (j *canceledJob) Run() {
  fmt.Println("job run")
}

c := gron.New()
c.AddFuncWithJobID(gron.Every(1*time.Second), "job-id-1", func() {
	fmt.Println("runs every second")
})
c.AddCancelingJob(Every(1*time.Second), &canceledJob{id: "job-id-2"})
c.Start()

time.Sleep(5 * time.Second)

c.Cancel("job-id-1")
c.Cancel("job-id-2")

Full Example

package main

import (
	"fmt"
	"time"

	"github.com/fakeyanss/gron"
	"github.com/fakeyanss/gron/xtime"
)

type printJob struct{ Msg string }

func (p printJob) Run() {
	fmt.Println(p.Msg)
}

type canceledJob struct { // implements of JobWithCancel interface
	id string
}

func (j *canceledJob) JobID() string {
	return j.id
}

func (j *canceledJob) Run() {
	fmt.Printf("job %s run\n", j.id)
}

func main() {
	var (
		daily     = gron.Every(1 * xtime.Day)
		weekly    = gron.Every(1 * xtime.Week)
		monthly   = gron.Every(30 * xtime.Day)
		yearly    = gron.Every(365 * xtime.Day)
		purgeTask = func() { fmt.Println("purge unwanted records") }
		printFoo  = printJob{"Foo"}
		printBar  = printJob{"Bar"}
	)

	c := gron.New()

	c.AddFunc(gron.Every(1*time.Hour), func() {
		fmt.Println("Every 1 hour")
	})
	c.Start()

	c.AddFunc(weekly, func() { fmt.Println("Every week") })
	c.Add(daily.At("12:30"), printFoo)
	c.Start()

	// Jobs may also be added to a running Cron
	c.Add(monthly, printBar)
	c.AddFunc(yearly, purgeTask)

	c.AddFuncWithJobID(gron.Every(1*time.Second), "job-id-1", func() {
		fmt.Println("job-id-1 runs every second")
	})
	c.AddCancelingJob(gron.Every(1*time.Second), &canceledJob{id: "job-id-2"})
	c.Start()

	time.Sleep(5 * time.Second)
	c.Cancel("job-id-1")
	time.Sleep(5 * time.Second)

	// Stop the scheduler (does not stop any jobs already running).
	defer c.Stop()
}