golang 定时任务
lambdang 人气:0前言
项目中经常有定时任务的需求,一般都是利用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翻以前做过的代码,这次总结一下,下次直接翻这篇文章了,你也可以收藏起来,用到时候查询一下。
加载全部内容