上网查了下相关资料,基本上都介绍的是github.com\robfig\cron这个包来执行定时任务,试了下确实可以执行。但是此包下没有删 除任务的方法,只有暂停的方法(Stop),若要停止之前的任务只执行新定义的任务,除非服务器重启再定义新任务。后来又参考了一下其他人的建议,采用了 github.com\jakecoffman\cron这个包。后者是在前者的基础上做了一定的修改,给每个任务添加的一个新属性Name,然后新添加 一个remove(name)方法,用来删除指定名字的任务,经测试使用后可正常删除任务,只不过之前的计划任务名得新建一个全局变量来存储。

以下先简单介绍下定义时间集合的信息:

字段名 是否必须 允许的值 允许的特定字符
秒(Seconds) 0-59
* / , -
分(Minutes) 0-59
* / , -
时(Hours) 0-23
* / , -
日(Day of month) 1-31
* / , – ?
月(Month) 1-12 or JAN-DEC
* / , -
星期(Day of week) 0-6 or SUM-SAT
* / , – ?

注:
1)月(Month)和星期(Day of week)字段的值不区分大小写,如:SUN、Sun 和 sun 是一样的。
2)星期
(Day of week)字段如果没提供,相当于是 *

2、特殊字符说明
1)星号(*)
表示 cron 表达式能匹配该字段的所有值。如在第5个字段使用星号(month),表示每个月

回到顶部
2)斜线(/)
表示增长间隔,如第1个字段(minutes) 值是 3-59/15,表示每小时的第3分钟开始执行一次,之后每隔 15 分钟执行一次(即 3、18、33、48 这些时间点执行),这里也可以表示为:3/15

回到顶部
3)逗号(,)
用于枚举值,如第6个字段值是 MON,WED,FRI,表示 星期一、三、五 执行

回到顶部
4)连字号(-)
表示一个范围,如第3个字段的值为 9-17 表示 9am 到 5pm 直接每个小时(包括9和17)

回到顶部
5)问号(?)
只用于 日(Day of month) 和 星期(Day of week),表示不指定值,可以用于代替 *

在beego下使用,我简单的封装一下(代码不是我写的,而且写的很随意,也只保证了可用的程度),自定义package jobs如下:

job.go源码:

  1. package jobs
  2. import (
  3. "github.com/astaxie/beego"
  4. "github.com/jakecoffman/cron"
  5. "reflect"
  6. "runtime/debug"
  7. "sync"
  8. "sync/atomic"
  9. )
  10. type Job struct {
  11. Name    string
  12. inner   cron.Job
  13. status  uint32
  14. running sync.Mutex
  15. }
  16. const UNNAMED = "(unnamed)"
  17. func New(job cron.Job) *Job {
  18. name := reflect.TypeOf(job).Name()
  19. if name == "Func" {
  20. name = UNNAMED
  21. }
  22. return &Job{
  23. Name:  name,
  24. inner: job,
  25. }
  26. }
  27. func (j *Job) Status() string {
  28. if atomic.LoadUint32(&j.status) > 0 {
  29. return "RUNNING"
  30. }
  31. return "IDLE"
  32. }
  33. func (j *Job) Run() {
  34. // If the job panics, just print a stack trace.
  35. // Don't let the whole process die.
  36. defer func() {
  37. if err := recover(); err != nil {
  38. beego.Error("%v", debug.Stack())
  39. }
  40. }()
  41. if !selfConcurrent {
  42. j.running.Lock()
  43. defer j.running.Unlock()
  44. }
  45. if workPermits != nil {
  46. workPermits <- struct{}{}
  47. defer func() { <-workPermits }()
  48. }
  49. atomic.StoreUint32(&j.status, 1)
  50. defer atomic.StoreUint32(&j.status, 0)
  51. j.inner.Run()
  52. }

jobrunner.go源码:

  1. // A job runner for executing scheduled or ad-hoc tasks asynchronously from HTTP requests.
  2. //
  3. // It adds a couple of features on top of the cron package to make it play nicely with Revel:
  4. // 1. Protection against job panics.  (They print to ERROR instead of take down the process)
  5. // 2. (Optional) Limit on the number of jobs that may run simulatenously, to
  6. //    limit resource consumption.
  7. // 3. (Optional) Protection against multiple instances of a single job running
  8. //    concurrently.  If one execution runs into the next, the next will be queued.
  9. // 4. Cron expressions may be defined in app.conf and are reusable across jobs.
  10. // 5. Job status reporting.
  11. package jobs
  12. import (
  13. //"fmt"
  14. "github.com/jakecoffman/cron"
  15. "time"
  16. )
  17. // Callers can use jobs.Func to wrap a raw func.
  18. // (Copying the type to this package makes it more visible)
  19. //
  20. // For example:
  21. //    jobs.Schedule("cron.frequent", jobs.Func(myFunc))
  22. type Func func()
  23. func (r Func) Run() { r() }
  24. //定时执行任务
  25. func Schedule(spec string, job cron.Job, name string) error {
  26. sched := cron.Parse(spec)
  27. /*if err != nil {
  28. return err
  29. }*/
  30. MainCron.Schedule(sched, New(job), name)
  31. return nil
  32. }
  33. // Run the given job at a fixed interval.
  34. // The interval provided is the time between the job ending and the job being run again.
  35. // The time that the job takes to run is not included in the interval.
  36. func Every(duration time.Duration, job cron.Job, name string) {
  37. MainCron.Schedule(cron.Every(duration), New(job), name)
  38. }
  39. // Run the given job right now.
  40. func Now(job cron.Job) {
  41. go New(job).Run()
  42. }
  43. // Run the given job once, after the given delay.
  44. func In(duration time.Duration, job cron.Job) {
  45. go func() {
  46. time.Sleep(duration)
  47. New(job).Run()
  48. }()
  49. }
  50. // 暂停所有任务
  51. func Stop() {
  52. MainCron.Stop()
  53. }
  54. //清空任务
  55. func Remove(name string) {
  56. MainCron.RemoveJob(name)
  57. }

plugin.go源码:

  1. package jobs
  2. import (
  3. "github.com/jakecoffman/cron"
  4. )
  5. const DEFAULT_JOB_POOL_SIZE = 10
  6. var (
  7. // Singleton instance of the underlying job scheduler.
  8. MainCron *cron.Cron
  9. // This limits the number of jobs allowed to run concurrently.
  10. workPermits chan struct{}
  11. // Is a single job allowed to run concurrently with itself?
  12. selfConcurrent bool
  13. )
  14. func init() {
  15. MainCron = cron.New()
  16. workPermits = make(chan struct{}, DEFAULT_JOB_POOL_SIZE)
  17. selfConcurrent = false
  18. MainCron.Start()
  19. }

因为是网站执行定时任务,这边我是将任务是否开启的控制权放在前端页面,通过点击按钮访问controller方法,从而启动任务,所以我把任务执行方法放在了controller中。通过如下方式调用:

  1. import (
  2. //其他引用包我都省略了
  3. "hnnaserver/src/jobs"
  4. )
  5. type job struct {
  6. user     string
  7. province int64
  8. method   int64
  9. count    int64
  10. }
  11. //任务执行的方法
  12. func (j *job) Run() {
  13. //do something....
  14. }
  15. func (this *SystemController) AutoDisCus() {
  16. spec := "0 0 15 * * 1-5"//定义执行时间点 参照上面的说明可知 执行时间为 周一至周五每天15:00:00执行
  17. //spec := "*/5 * * * * ?" //这是网上一般的例子 即每5s执行一次
  18. j := &job{user, province, method, count}
  19. jobs.Schedule(spec, j, taskName) //3个参数分别为 执行时间(规则之间介绍过) 要执行的任务  任务名
  20. }

若要删除某项任务,则调用remove方法即可,如下:

    1. jobs.Remove(tasksName)

golang 定时器的更多相关文章

  1. [Go] golang定时器与redis结合

    golang定时器与redis结合,每隔1秒ping一下,每隔20秒llen一下队列的长度 package main import ( "fmt" "time" ...

  2. Golang定时器断续器

    定时器 1.定时器结构 结构定义 type Timer struct { C <-chan Time // 接受定时器事件的通道 r runtimeTimer } type runtimeTim ...

  3. [Go] golang定时器的使用

    golang中的定时器是使用的chanel阻塞来实现的,主要使用到了time包中的内容,如果有多个定时器的channel,为了防止阻塞,可以使用select来获取遍历channel 定时器获取的cha ...

  4. 一周学会go语言并应用 by王奇疏

    <一周学会go语言并应用> by王奇疏 ( 欢迎加入go语言群: 218160862 , 群内有实践) 点击加入 零.安装go语言,配置环境及IDE 这部分内容不多,请参考我的这篇安装环境 ...

  5. Golang之定时器,recover

    滴答滴答……定时器的使用 package main import ( "fmt" "time" ) //定时器的使用 func main() { t := ti ...

  6. 生产者消费者模式做一个golang的定时器

    在主程序启动的时候开一个goroutine作为消费者,用管道连接生产者和消费者,消费者处于无限循环,从管道中获取channel传过来定时event 注意:channel在消费者创建的时候就连通生产者和 ...

  7. golang 中的定时器(timer),更巧妙的处理timeout

    今天看到kite项目中的一段代码,发现挺有意思的. // generateToken returns a JWT token string. Please see the URL for detail ...

  8. golang的定时器NewTimer、NewTicker使用

    package main import ( "fmt" "sync" "time" ) /** *ticker只要定义完成,从此刻开始计时, ...

  9. [Golang]-7 定时器和打点器

    目录 定时器 打点器 After()方法 我们常常需要在未来某个时刻运行 Go 代码,或者在某段时间间隔内重复运行. Go 的内置 定时器 和 打点器 特性让这些很容易实现. 定时器 type Tim ...

随机推荐

  1. 【转】SVN提示:由于目标机器积极拒绝,无法连接 的解决方法

    转载地址:http://wxiaolei.blog.163.com/blog/static/1038760120133108180596/ 安装完TSVN之后,checkout时报错,并且后来在cmd ...

  2. java.lang.VerifyError异常

    以前遇到过java.lang.VerifyError 原因是jar包冲突 tomcat6自带jsp.jar.servlet.jar所以项目中不用引入 tomcat5不带jsp.jar.servlet. ...

  3. JAVA基础知识之多线程——控制线程

    join线程 在某个线程中调用其他线程的join()方法,就会使当前线程进入阻塞状态,直到被join线程执行完为止.join方法类似于wait, 通常会在主线程中调用别的线程的join方法,这样可以保 ...

  4. Uva 10118 免费糖果

    题目链接:https://uva.onlinejudge.org/external/101/10118.pdf 参考:http://www.cnblogs.com/kedebug/archive/20 ...

  5. kindeditor编辑器

    一 简单使用方法 1. 把所有文件上传到程序所在目录下,例如:http://你的域名/editor/. 2. 在此目录下创建attached文件夹,并把权限改成777. 3. 要添加编辑器的地方加入以 ...

  6. sql 百万级数据库优化方案

    转自http://blog.sina.com.cn/s/blog_724cd89d0100ppcz.html 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉 ...

  7. 织梦cms PHPcms 帝国cms比较

    现在建网站不需要请程序员从基础的程序开发做起了,有专业的建站工具,CMS是使用最广泛的建站工具.CMS是Content Management System 现在建网站不需要请程序员从基础的程序开发做起 ...

  8. 看看,这就是微软的“万物互联”系统 window10 IOT

    今天在深圳 WinHEC2015 大会上,微软正式发布了其基于 Windows 10 开发的,专门用于一系列物联网设备的操作系统:Windows 10 IoT for Smart Devices(是的 ...

  9. node-webkit中使用sqlite3(MAC平台)

    前言 最近使用node-webkit开发一款博客发布软件,来替换难用的Windows Live Writer(主要是对Markdown标签的支持很差劲).为了解决博文信息临时保存的问题,想到了使用sq ...

  10. 【转载】nedmalloc结构分析

    原文:nedmalloc结构分析 nedmalloc是一个跨平台的高性能多线程内存分配库,很多库都使用它,例如:OGRE.现在我们来看看nedmalloc的实现 (以WIN32部分为例)    位操作 ...