当前位置: 首页 > article >正文

golang开源定时任务调度框架

golang开源定时任务调度框架

Go语言中有很多开源的定时任务调度框架,以下几个是比较流行常用的:

golang开源定时任务框架介绍

  • cron

一个基于Cron表达式的定时任务库,可以精确到秒级。它提供了简单易用的API来定义和管理定时任务,支持任务暂停、恢复、删除等操作,同时还能够在多个节点之间共享状态信息。
目前在github中的star最多,最为流行。
官方网站地址:https://github.com/robfig/cron

  • go-crontab

一个轻量级的定时调度库,也是基于Cron表达式的。它支持多种调度方式,包括分布式调度、集群调度,同时还提供了Web控制台和RESTful API接口,非常方便使用。
一个定时任务管理器,基于Go语言和beego框架开发。用于统一管理项目中的定时任务,提供可视化配置界面、执行日志记录、邮件通知等功能,无需依赖*unix下的crontab服务。
官方网站地址:https://github.com/lisijie/webcron

  • jobrunner

一个简单易用的定时任务库,它支持按照时间周期或按照固定时间点执行任务。除此之外,还支持异步任务、任务重试、延迟任务等功能。
官方网站地址:https://github.com/bamzi/jobrunner

  • gocron

另一个基于Cron表达式的定时任务库,它可以让你以链式调用的方式定义任务,并且支持任务组、任务优先级等功能。
官方网站地址:https://github.com/go-co-op/gocron

总之,这些库使用起来都比较简单,你可以根据自己的需求和喜好选择其中一个来使用。因为每个定时框架都有其自身的优点和适用场景。以下是每个框架的一些特点仅供参考:

golang开源定时任务框架对比

  • cron
    目前在github中的star最多,得到广泛的使用和测试。评测结果表明,与其他相比,它拥有最高的调度准确性,尤其在较高负载下。它也有宽松的开源许可证,允许你做任何你想做的事情。

  • go-crontab
    基于Go语言和beego框架开发,可以运行多个实例(master/扇脸ave)并支持分布式部署。易于集成,并提供了控制台和API接口。在Go语言中编写,易于维护和扩展。

  • jobrunner
    拥有丰富的功能,包括异步任务、任务重试、延迟任务等。具有充分的单元测试和文档支持。代码简单而直观。

  • gocron
    支持链式调用,非常易于使用。可以定义任务组、任务优先级等。在调度方面表现良好,但没有经过广泛测试。

总结:因此,选择哪个库主要取决于您的需求和偏好。如果你需要更高的调度准确性和稳定性,那么cron可能是一个不错的选择;
如果你需要分布式调度和控制台支持,那么go-crontab可能更适合你。而如果你需要更多的功能和灵活性,那么jobrunner可能更适合你。

我目前选择的是:cron,因为在github中的star最多,最为流行,能得到广泛的使用和测试,而且它的性能比较好。

cron使用

官方地址:https://github.com/robfig/cron

下载依赖包

go get github.com/robfig/cron/v3@v3.0.0

cron的封装如下示例:

import "github.com/robfig/cron/v3"

var C *cron.Cron
// 记录启动的任务EntryId
var TaskEntryIdMap map[string]cron.EntryID

func TaskInit() {
	TaskEntryIdMap = make(map[string]cron.EntryID)

	//创建一个定时任务对象,根据cron表达式进行时间调度,cron可以精确到秒,大部分表达式格式也是从秒开始
	// 默认从分开始进行时间调度
	//C = cron.New()
	//精确到秒
	C = cron.New(cron.WithSeconds())
	
	// 这里可以查询数据库里的定时任务,加载进来。
	
	//启动
	C.Start()
}

// 添加定时任务
func AddFuncTask(taskId, name, desc, cron string, param map[string]interface{}, cmd func(map[string]interface{})) bool {
	entryId, err := C.AddFunc(cron, func() {
		cmd(param)
	})
	if err != nil {
		Log.Error("task AddFuncTask start error:", err)
		return false
	}

	//这里可以把定时任务保存到数据库,重启程序时,可以从数据库加载定时任务
	
	addEntryId(taskId, entryId)
	return true
}

// 删除定时任务
func DeleteTask(taskId string) {
	C.Remove(TaskEntryIdMap[taskId])
	deleteEntryId(taskId)
	
	//从数据库删除任务
}

func addEntryId(taskId string, entryId cron.EntryID) {
	TaskEntryIdMap[taskId] = entryId
}

func deleteEntryId(taskId string) {
	delete(TaskEntryIdMap, taskId)
}

func TaskClose() {
	//关闭cron
	C.Stop()
}

func main() {
	//初始化定时任务
	TaskInit()
	
	//其他业务初始化
	
	//关闭定时任务
	TaskClose()
}

以上示例根据业务动态调整,可以把定时任务保存到数据库,当程序重启的时候从数据库把定时任务查询出来,在启动执行。

基于cron表达式定时监控,支持任务的总体启动暂停和单个任务的启动暂停
https://github.com/dhjz/dwatch

参考链接:
https://blog.csdn.net/u013421629/article/details/129981594


http://www.kler.cn/a/228367.html

相关文章:

  • 接口 V2 完善:基于责任链模式、Canal 监听 Binlog 实现数据库、缓存的库存最终一致性
  • 【组件库】使用Vue2+AntV X6+ElementUI 实现拖拽配置自定义vue节点
  • C++priority_queue模拟实现
  • 75,【7】BUUCTF WEB [Weblogic]SSRF(未作出)
  • linux网络 | 传输层TCP | 认识tcp报头字段与分离
  • Linux内核中的InfiniBand核心驱动:verbs.c分析
  • 基于SSM+MySQL的的新闻发布系统设计与实现
  • SQL Server 函数参考手册(SQL Server 数值函数)
  • idea 快捷键ctrl+shift+f失效的解决方案
  • 【目标跟踪】相机运动补偿
  • 从[redis:LinkedList]中学习链表
  • LlamaIndex 入门实战
  • 力扣_字符串3—通配符匹配
  • 机器学习复习(8)——基本概念
  • kubesphere部署k8s-v1.23.10
  • 2024美赛数学建模C题完整论文教学(含十几个处理后数据表格及python代码)
  • 机器学习本科课程 实验4 支持向量机
  • 视频融合平台EasyCVR推流成功但平台显示不在线是什么原因?
  • HarmonyOS ArkTS Button基本使用(十八)
  • 【go】结构体切片去重
  • 【Node系列】node中的流(Stream)
  • 16-Verilog实现二线制I2C CMOS串行EEPROM的读写操作
  • 【Java报错】显示错误“Error:java: 程序包org.springframework.boot不存在“
  • ArrayList和LinkedList的区别是什么
  • ASP.NET Core 预防开放式重定向攻击
  • JAVA斗地主逻辑-控制台版