Skip to content

The cron library is a cron job library for Go. It is a fork of robfig/cron with some improvements.

License

Notifications You must be signed in to change notification settings

flc1125/go-cron

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ddb3f69 Â· Dec 14, 2024
Dec 6, 2024
Dec 6, 2024
Dec 6, 2024
Dec 6, 2024
Oct 26, 2024
Oct 26, 2024
Dec 6, 2024
Dec 6, 2024
Oct 26, 2024
Dec 7, 2013
Dec 7, 2013
Nov 19, 2024
Nov 19, 2024
Oct 28, 2024
Nov 2, 2024
Oct 28, 2024
Dec 14, 2024
Dec 14, 2024
Oct 26, 2024
Oct 26, 2024
Oct 26, 2024
Oct 28, 2024
Oct 28, 2024
Oct 26, 2024
Oct 26, 2024
Dec 2, 2024
Oct 26, 2024
Dec 14, 2024
Oct 26, 2024
Oct 26, 2024

Repository files navigation

Cron

Supported Go Versions Package Version GoDoc codecov Go Report Card lint tests MIT license

The cron library is a cron job library for Go.

It is a fork of robfig/cron with some improvements.

Thanks to robfig/cron for the original work, and thanks to all the contributors.

Important

v4.x may introduce situations that are not backward compatible.

The reason for this is that we are using v4.x as a transitional version. In this version, we will try to improve the functionality of the components as much as possible until the release of v5.x.

When releasing a new version, backward compatibility is the default behavior. If there are any incompatibilities, they will be indicated in the release notes.

Installation

go get github.com/flc1125/go-cron/v4

Usage

package main

import (
	"context"

	"github.com/flc1125/go-cron/v4"
	"github.com/flc1125/go-cron/v4/middleware/nooverlapping"
	"github.com/flc1125/go-cron/v4/middleware/recovery"
)

func main() {
	c := cron.New(
		cron.WithSeconds(), // if you want to use seconds, you can use this option
		cron.WithMiddleware(
			recovery.New(),      // recover panic
			nooverlapping.New(), // prevent job overlapping
		),
		cron.WithContext(context.Background()), // use custom context
		// ... other options
	)

	// use middleware
	c.Use(recovery.New(), nooverlapping.New()) // use middleware

	// add job
	entryID, _ := c.AddJob("* * * * * *", cron.JobFunc(func(ctx context.Context) error {
		// do something
		return nil
	}))
	_ = entryID

	// add func
	_, _ = c.AddFunc("* * * * * *", func(ctx context.Context) error {
		// do something
		return nil
	}, recovery.New(), nooverlapping.New()) // use middleware for this job

	// start cron
	c.Start()

	// stop cron
	c.Stop()
}

Middleware

  • recovery: Recovers from panics in job execution, ensuring system stability.
  • delayoverlapping: Delays execution of overlapping jobs instead of running them concurrently.
  • nooverlapping: Prevents concurrent execution of the same job.
  • distributednooverlapping: Prevents concurrent execution across multiple instances using distributed locking.
  • otel: Provides OpenTelemetry integration for job execution tracing.

License