golang常用定时任务汇总
前言
项目中经常有定时任务的需求,一般都是利用linux的cron命令,定时执行脚本,无论从管理上来说还是从开发上来说都不是最好的方案,要是能在项目里直接开发定时任务,就比较完美了。
golang利用goroutine外加github.com/gorhill/cronexpr库就可实现定时任务,代码简单,原理简单。
cronexpr库
定时语法介绍
该库是一个定时字符串规则解析库,同linux中的cron类似,但是可以精确到秒,也可以设定年,可以直接到git里查看,这里只对最常用的规则进行解释。
索引 | 字段名 | 是否必须 | 值范围 | 可用字符串 |
---|---|---|---|---|
1 | 秒 | 否 | 0-59 | * / , - |
2 | 分 | 是 | 0-59 | * / , - |
3 | 时 | 是 | 0-23 | * / , - |
4 | 日(月中) | 是 | 1-31 | * / , - L W |
5 | 月 | 是 | 1-12 | * / , - |
6 | 日(星期中) | 是 | 0-6 | * / , - L # |
7 | 年 | 否 | 1970-2099 | * / , - |
- 星号(*) 表示该字段所有的值,例:每秒 、每天。
- 斜线(/) 范围增量,例: 分钟 3-59/15 表示3分到59分中从第3分开始,每15分中一次,分钟 */15 表示0-59分钟,从0分钟开始,每15分钟1次。*在这里表示全范围。
- 逗号(,) 分割列表中的项目,例:星期1,星期2,星期3 表示为 0,1,2
- 连字符(-) 表示范围,列,2000年到2010年表示为 2000-2010
L w # 不常用
常用定时
每日 即每天凌晨零点:0 0 0 * * * *
每日凌晨2点: 0 0 2 * * * *
每月开始: 0 0 0 1 * * *
每周开始: 0 0 0 * * 1 * 注意 0是星期天
定时代码
func Task () {
cron := cronexpr.MustParse("0 0 0 * * * *") //用cron库生成一个cronexpr.Expression对象
next := cron.Next(time.Now()) //计算下次触发时间的时间对象
for {
now := time.Now() //每次循环计算获取当前时间
if next.Before(now) || next.Equal(now) { //下次触发时间与当前时间进行对比,等于或者时间已到 则进行任务触发
... //此处填写任务代码
next = cron.Next(now) //重新计算下次任务时间的时间对象
}
select {
case <-time.NewTicker(time.Second).C: //每秒扫描一遍 循环频率设定
}
}
}
代码里注释已经很清楚了。在整理一下步骤:
- 先根据定时规则生成一个 cronexpr.Expression 对象,简称cron对象。
- 循环中判断当前时刻和cron计算的下次时刻是否已经到达。
- 已经到达则运行定时任务代码并重新计算下次到达时刻。
- 设定循环频率,根据实际情况设定循环频率。
结语
golang定时任务的代码很简单,定时任务规则语法与linux cron相似,我总是记不住,每次用到时候就去翻git翻以前做过的代码,这次总结一下,下次直接翻这篇文章了,你也可以收藏起来,用到时候查询一下。
到此这篇关于golang 常用定时任务汇总的文章就介绍到这了,更多相关golang 定时任务内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341