目录
前言快速开始安装导入DemoCron表达式格式标准格式预定义时间表常用的方法介绍new()AddJob()AddFunc()Start()相关推荐Go第三方库之cronexpr——解析 crontab 表达式总结前言
在平时的开发需求中,我们经常会有一些重复执行的操作需要触发执行,和系统约个时间,在几点几分几秒或者每隔几分钟跑一个任务,说白了就是定时任务,,想必大家第一反应都是linux的Crontab。其实定时任务不止使用系统自带的Crontab,在Go语言中也可以使用Cron定时任务库, 这篇文章给大家介绍如何在go项目中实现一个crontab功能,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
golang 实现定时服务很简单,只需要简单几步代码便可以完成,不需要配置繁琐的服务器,直接在代码中实现。
(资料图)
使用 github.com/robfig/cron 这个包,robfig/cron是一个第三方开源的任务调度库,也就是我们平时说的定时任务,它实现了 cron 规范解析器和任务运行器。
快速开始
安装
go get github.com/robfig/cron/v3@v3.0.0
导入
import "github.com/robfig/cron/v3"
Demo
package main import ( "fmt" "github.com/robfig/cron/v3" ) func main() { // 创建一个默认的cron对象 c := cron.New() //添加执行任务 c.AddFunc("30 * * * *", func() { fmt.Println("Every hour on the half hour") }) c.AddFunc("@hourly", func() { fmt.Println("Every hour, starting an hour from now") }) c.AddFunc("@every 1h30m", func() { fmt.Println("Every hour thirty, starting an hour thirty from now") }) //开始执行任务 c.Start() select {} //阻塞 }
Cron表达式格式
标准格式
一个 cron 表达式表示一组时间,使用 5 个空格分隔的字段。这是v3版本默认支持的格式,没有Seconds。在v3版本中也支持秒级别的解析,需要自定义解析器。
Field name | Mandatory? | Allowed values | Allowed special characters ---------- | ---------- | -------------- | -------------------------- Seconds | Yes | 0-59 | * / , - Minutes | Yes | 0-59 | * / , - Hours | Yes | 0-23 | * / , - Day of month | Yes | 1-31 | * / , - ? Month | Yes | 1-12 or JAN-DEC | * / , - Day of week | Yes | 0-6 or SUN-SAT | * / , - ?
预定义时间表
可以用@yearly
、@monthly
、@weekly
、@weekly
、@daily
、@hourly
来替代cron表达式。分别表示每年,每月、每星期、每天、每小时。
还可以用@every
来表示间隔时间,即间隔执行一次任务。只要可以被time.ParseDuration()
解析即可。
常用的方法介绍
new()
会根据本地时间创建一个新(空白)的计划任务实例
// 创建一个默认的cron对象 cron.New() // 自定义解析器 cron.New(cron.WithSeconds()) // Seconds field, optional cron.New(cron.WithParser(cron.NewParser( cron.SecondOptional | cron.Minute | cron.Hour | cron.Dom | cron.Month | cron.Dow | cron.Descriptor, )))
AddJob()
// 有两个参数,第一个参数可以是cron表达式或者预定义时间表,第二个Job func (c *Cron) AddJob(spec string, cmd Job) (EntryID, error) // Job是一个接口,有一个Run方法 type Job interface { Run() }
AddFunc()
会向计划任务实例中添加一个回调函数,按指定时间表执行回调函数。
// 有两个参数,第一个参数可以是cron表达式或者预定义时间表,第二个传入一个函数,就是要执行的任务 // 会返回一个Id和error // 会把传入的cmd func转成FuncJob。FuncJob实现了Job接口 func (c *Cron) AddFunc(spec string, cmd func()) (EntryID, error) { return c.AddJob(spec, FuncJob(cmd)) }
Start()
调用start方法开始执行任务
相关推荐
Go第三方库之cronexpr——解析 crontab 表达式
cronexpr 是一个 crontab 解析表达式的库,我们可以根据当前时间获取到下次执行的时间。具体用法如下:
go get github.com/gorhill/cronexpr //下载 import "github.com/gorhill/cronexpr" //导入
demo:
package main import ( "fmt" "time" "github.com/gorhill/cronexpr" ) func doTask() { fmt.Println("I am running, time is: ", time.Now()) } func main() { // 每隔 5 秒执行1次 expr, err := cronexpr.Parse("*/10 * * * * * * ") // 如果表达式解析错误将返回一个错误 if err != nil { fmt.Println(err) return } //获取下次执行时间 nextTime := expr.Next(time.Now()) fmt.Println(nextTime) time.AfterFunc(time.Until(nextTime), doTask) //返回当前crontab后的5次执行,n为次数 nextTimeList = cronexpr.MustParse("*/10 * * * * * * ").NextN(time.Now(), 5) for _, v := range nextTimeList { fmt.Println(v.String()) } time.Sleep(10 * time.Second) }
总结
定时任务很常见,希望你通过本文能够熟知 Golang 怎么实现一个简单的定时任务调度管理
可以不依赖系统的 Crontab 设置,指不定哪一天就用上了。
到此这篇关于一文带你入门Go语言中定时任务库Cron的使用的文章就介绍到这了,更多相关Go语言定时任务库Cron内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
X 关闭
X 关闭
- 1联想拯救者Y70发布最新预告:售价2970元起 迄今最便宜的骁龙8+旗舰
- 2亚马逊开始大规模推广掌纹支付技术 顾客可使用“挥手付”结账
- 3现代和起亚上半年出口20万辆新能源汽车同比增长30.6%
- 4如何让居民5分钟使用到各种设施?沙特“线性城市”来了
- 5AMD实现连续8个季度的增长 季度营收首次突破60亿美元利润更是翻倍
- 6转转集团发布2022年二季度手机行情报告:二手市场“飘香”
- 7充电宝100Wh等于多少毫安?铁路旅客禁止、限制携带和托运物品目录
- 8好消息!京东与腾讯续签三年战略合作协议 加强技术创新与供应链服务
- 9名创优品拟通过香港IPO全球发售4100万股 全球发售所得款项有什么用处?
- 10亚马逊云科技成立量子网络中心致力解决量子计算领域的挑战