Gone框架介绍20 - 用cron表达式配置定时任务

gone是可以高效开发Web服务的Golang依赖注入框架
github地址:https://github.com/gone-io/gone
文档地址:https://goner.fun/zh/

用cron表达式配置定时任务

定时任务对于Web项目基本上时标配,可以通过Gone的内置组件来实现定时任务,支持cron表达式。在Web项目中代码一般都是多节点运行,我们使用了redis作为分布式锁来保证任务每次执行只在一个节点上进行,所以需要先准备redis服务,关于redis相关内容请参考:利用redis提供分布式锁和分布式缓存。另外定时任务还可以和框架“配置注入”的特性结合,将cron表达式放到配置文件中,参考通过内置Goners支持配置文件

将相关Goners埋葬到Cemetery

	//使用 goner.SchedulePriest 函数,将 定时任务 相关的Goner 埋葬到 Cemetery 中
	_ = goner.SchedulePriest(cemetery)

编写定时任务执行的Job函数

type sch struct {
	gone.Flag
}

func (sch *sch) job1() {
	//todo 定时任务逻辑
}

设置定时任务

实现Cron(run schedule.RunFuncOnceAt) ,框架会扫描结构体上的该方法并自动执行,在该方法中设置定时任务。

func (sch *sch) Cron(run schedule.RunFuncOnceAt) {

	//使用 run `RunFuncOnceAt`设置定时任务,
	run(
		"*/5 * * * * *", // cron 表达式,表示每5秒执行一次
		"job1",          //需要设置一个唯一标识,用于 分布式锁加锁
		sch.job1,        // 定时任务逻辑
	)
}

完整的demo代码如下:

package main

import (
	"fmt"
	"github.com/gone-io/gone"
	"github.com/gone-io/gone/goner"
	"github.com/gone-io/gone/goner/schedule"
)

func priest(cemetery gone.Cemetery) error {

	//使用 goner.SchedulePriest 函数,将 定时任务 相关的Goner 埋葬到 Cemetery 中
	_ = goner.SchedulePriest(cemetery)

	cemetery.Bury(&sch{})
	return nil
}

type sch struct {
	gone.Flag
}

func (sch *sch) job1() {
	//todo 定时任务逻辑
	fmt.Println("job1 execute")
}

func (sch *sch) Cron(run schedule.RunFuncOnceAt) {

	//使用 run `RunFuncOnceAt`设置定时任务,
	run(
		"*/5 * * * * *", // cron 表达式,表示每5秒执行一次
		"job1",          //需要设置一个唯一标识,用于 分布式锁加锁
		sch.job1,        // 定时任务逻辑
	)
}

func main() {
	gone.Serve(priest)
}

上面代码会每隔5s打印:job1 execute,是不是很简单?

将定时配置放到配置文件中

将定时配置放到配置文件中,代码上只需要做如下3点修改:

  1. 将配置文件支持的相关Goner 埋葬到 Cemetery 中
  2. 注入放到配置文件的定时任务配置
  3. 使用从配置文件注入的定时配置设置定时任务

修改后的代码如下:

package main

import (
	"fmt"
	"github.com/gone-io/gone"
	"github.com/gone-io/gone/goner"
	"github.com/gone-io/gone/goner/config"
	"github.com/gone-io/gone/goner/schedule"
)

func priest(cemetery gone.Cemetery) error {

	//使用 goner.SchedulePriest 函数,将 定时任务 相关的Goner 埋葬到 Cemetery 中
	_ = goner.SchedulePriest(cemetery)

	//1.将配置文件支持的相关Goner 埋葬到 Cemetery 中
	_ = config.Priest(cemetery)

	cemetery.Bury(&sch{})
	return nil
}

type sch struct {
	gone.Flag

	cron string `gone:"config,cron.job1,default=*/5 * * * * *"` //2. 注入放到配置文件的定时任务配置
}

func (sch *sch) job1() {
	//todo 定时任务逻辑
	fmt.Println("job1 execute")
}

func (sch *sch) Cron(run schedule.RunFuncOnceAt) {

	//使用 run `RunFuncOnceAt`设置定时任务,
	run(
		sch.cron, // 3. 使用从配置文件注入的定时配置
		"job1",   //需要设置一个唯一标识,用于 分布式锁加锁
		sch.job1, // 定时任务逻辑
	)
}

func main() {
	gone.Serve(priest)
}

求赞助

如果觉得还可以,请帮忙在github上点个 ⭐️吧:
github地址:https://github.com/gone-io/gone

福利🔥添加交流群,赠送 Golang 多套 学习资料,夯实基础👍🏻👍🏻

上一篇:Gone框架介绍19 -如何进行单元测试?
下一篇:Gone框架介绍21 - 手把手教你封装一个Goner用于调用GPT对接强大的GPT4o

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dapeng-大鹏

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值