1. gocron

1.1.1. jasonlvhit/gocron

安装:

  1. go get -u github.com/jasonlvhit/gocron

每隔1秒执行一个任务,每隔4秒执行另一个任务:

  1. package main
  2. import (
  3. "fmt"
  4. "time"
  5. "github.com/jasonlvhit/gocron"
  6. )
  7. func task() {
  8. fmt.Println("I am runnning task.", time.Now())
  9. }
  10. func superWang() {
  11. fmt.Println("I am runnning superWang.", time.Now())
  12. }
  13. func main() {
  14. s := gocron.NewScheduler()
  15. s.Every(1).Seconds().Do(task)
  16. s.Every(4).Seconds().Do(superWang)
  17. sc := s.Start() // keep the channel
  18. go test(s, sc) // wait
  19. <-sc // it will happens if the channel is closed
  20. }
  21. func test(s *gocron.Scheduler, sc chan bool) {
  22. time.Sleep(8 * time.Second)
  23. s.Remove(task) //remove task
  24. time.Sleep(8 * time.Second)
  25. s.Clear()
  26. fmt.Println("All task removed")
  27. close(sc) // close the channel
  28. }

输出结果:

  1. I am runnning task. 2019-11-15 09:37:07.218128145 +0800 CST m=+1.000414542
  2. I am runnning task. 2019-11-15 09:37:08.218062127 +0800 CST m=+2.000348513
  3. I am runnning task. 2019-11-15 09:37:09.218047138 +0800 CST m=+3.000333512
  4. I am runnning superWang. 2019-11-15 09:37:10.218058701 +0800 CST m=+4.000345070
  5. I am runnning task. 2019-11-15 09:37:10.218100706 +0800 CST m=+4.000387079
  6. I am runnning task. 2019-11-15 09:37:11.218033085 +0800 CST m=+5.000319455
  7. I am runnning task. 2019-11-15 09:37:12.21804561 +0800 CST m=+6.000331978
  8. I am runnning task. 2019-11-15 09:37:13.218053083 +0800 CST m=+7.000339456
  9. I am runnning superWang. 2019-11-15 09:37:14.218038711 +0800 CST m=+8.000325086
  10. I am runnning superWang. 2019-11-15 09:37:18.218061128 +0800 CST m=+12.000347516
  11. I am runnning superWang. 2019-11-15 09:37:22.218054256 +0800 CST m=+16.000340629
  12. All task removed