golang cron包 获取上上次执行时间

AddFunc中使用Prev的小坑

使用 cron 包的定时功能,可以实现不等时间的定时,但我这里就简单的每一分钟执行一次计划。

计划是统计 上次触发现在 这个时间段之间的某些信息,我本以为使用cron的Prev就能很好的实现,但是测试时发现Prev的时间几乎就是本次执行的时间。

代码是这样的:

	func main() {
	cronSpec:= "0 */1 * * * ?"
	timeLayout := "2006-01-02_15:04:05"

	c := cron.New()
	_ = c.AddFunc(cronSpec, func() {
		fmt.Print("now: ", time.Now().Format(timeLayout))
		fmt.Printf("\nc.Entries()[0].Prev:%s\nc.Entries()[0].Next:%s",
			c.Entries()[0].Prev.Format(timeLayout), c.Entries()[0].Next.Format(timeLayout))
	})
	c.Start()

	select {}
	}

执行结果是这样的:

now: 2019-08-15_16:21:00
c.Entries()[0].Prev:2019-08-15_16:21:00
c.Entries()[0].Next:2019-08-15_16:22:00

now: 2019-08-15_16:22:00
c.Entries()[0].Prev:2019-08-15_16:22:00
c.Entries()[0].Next:2019-08-15_16:23:00

明显不是我要的效果,难道是因为在func()内获取上次时间,所以触发的时候已经更新过了Prev和Next ?
但不管啥原因,问题是总要解决的。
我的解决办法是直接动手改掉cron包的内容(我也不知道这样是不是被允许的。。)
给它增加个上上次的时间字段,这样不就解决了吗~

找到cron.go文件,修改如下内容:
在这里插入图片描述
这样就简单粗暴的给它加了个上上次时间(Preprev),解决了我的问题,同时代码修改如下:

	c := cron.New()
	_ = c.AddFunc(cronSpec, func() {
		fmt.Print("now: ", time.Now().Format(timeLayout))
		if c.Entries()[0].Preprev.IsZero() {
			fmt.Print(", and execute first time")
		} else {
			fmt.Printf("\nc.Entries()[0].Preprev:%s\nc.Entries()[0].Next:%s",
				c.Entries()[0].Preprev.Format(timeLayout), c.Entries()[0].Next.Format(timeLayout))
		}
	})
	c.Start()

现在执行效果如下:

now: 2019-08-15_16:56:00, and execute first time

now: 2019-08-15_16:57:00
c.Entries()[0].Preprev:2019-08-15_16:56:00
c.Entries()[0].Next:2019-08-15_16:58:00

now: 2019-08-15_16:58:00
c.Entries()[0].Preprev:2019-08-15_16:57:00
c.Entries()[0].Next:2019-08-15_16:59:00

完毕!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Golang 中,你可以使用第三方库,如 `robfig/cron` 或 `go-cron/cron` 来实现 cron 作业的延迟执行。 使用 `robfig/cron` 库的示例代码如下: ```go package main import ( "fmt" "time" "github.com/robfig/cron" ) func main() { c := cron.New() // 定义一个 cron 作业 job := cron.NewChain( cron.DelayIfStillRunning(cron.DefaultLogger), ).Then(cron.FuncJob(func() { fmt.Println("Hello, World!") })) // 设置作业的调度规则 schedule := "*/1 * * * * *" // 每秒执行一次 c.AddJob(schedule, job) // 启动 cron 作业 c.Start() // 延迟程序退出 time.Sleep(5 * time.Second) // 停止 cron 作业 c.Stop() } ``` 在上面的示例中,我们使用了 `cron.DelayIfStillRunning` 方法来延迟执行作业,这样即使上一个作业还在执行中,下一个作业也会按计划延迟执行。 另外,如果你使用的是 `go-cron/cron` 库,你可以使用 `cron.Delay` 方法来实现延迟执行。具体代码示例如下: ```go package main import ( "fmt" "time" "github.com/go-cron/cron" ) func main() { c := cron.New() // 定义一个 cron 作业 job := cron.NewChain( cron.Delay(5*time.Second), ).Then(cron.FuncJob(func() { fmt.Println("Hello, World!") })) // 设置作业的调度规则 schedule := "*/1 * * * * *" // 每秒执行一次 c.AddJob(schedule, job) // 启动 cron 作业 c.Start() // 延迟程序退出 time.Sleep(10 * time.Second) // 停止 cron 作业 c.Stop() } ``` 以上是两个常用的库来实现 golang cron 延迟执行的方法,你可以根据自己的实际需求选择使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值