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

在Spring框架中使用Cron表达式配置定时任务,可以通过定义一个方法并使用`@Scheduled`注解来实现。`@Scheduled`注解允许你指定一个Cron表达式来定义任务的执行计划。下面是具体的步骤: 1. 首先,确保你的Spring项目已经添加了对定时任务的支持。如果你使用的是Spring Boot,通常只需要在`pom.xml`或`build.gradle`文件中添加`spring-boot-starter`依赖即可,因为Spring Boot自动配置了任务调度相关的bean。 2. 创建一个组件(例如使用`@Component`或`@Service`注解标记的类),并在其中定义一个方法,这个方法将包含你希望定时执行的逻辑。 3. 在该方法上使用`@Scheduled`注解,并通过`cron`属性指定一个Cron表达式Cron表达式由六或七个空格分隔的时间字段组成,分别表示秒、分、时、日、月、周几(可选),其中年份字段是可选的。 例如:`@Scheduled(cron = "0 0/5 * * * *")` 表示每5分钟执行一次。 4. 确保你的Spring配置中有`@EnableScheduling`注解,以便Spring知道需要执行定时任务。 下面是一个简单的例子: ```java import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @Component public class ScheduledTasks { @Scheduled(cron = "0 0 10 * * ?") // 每天上午10点执行 public void performTask() { // 任务逻辑 System.out.println("执行定时任务,当前时间:" + System.currentTimeMillis()); } } ``` 5. 启动你的Spring应用程序。定时任务将根据你定义的Cron表达式自动执行。 需要注意的是,Spring的定时任务默认是单线程的。如果你需要并行执行多个定时任务,可能需要自定义`TaskScheduler`或者使用其他支持多线程的定时任务库。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

dapeng-大鹏

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

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

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

打赏作者

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

抵扣说明:

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

余额充值