目录
  • 前言
  • cronexpr库
    • 定时语法介绍
    • 常用定时
  • 定时代码
    • 结语

      前言

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

      声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。