網站首頁 編程語言 正文
快速入門
安裝cron,注意這里安裝的是v3版本。新版本和舊版時間使用有所區別
go get github.com/robfig/cron/v3@v3.0.0
在項目中導入
import "github.com/robfig/cron/v3"
v3版本的github.com/robfig/cron/v3
默認解析器符合Cron 維基百科頁面所描述的標準
用法大致如下
package main import ( "fmt" "github.com/robfig/cron/v3" ) func main() { c := cron.New() c.AddFunc("30 * * * *", func() { fmt.Println("Every hour on the half hour") }) c.AddFunc("30 3-6,20-23 * * *", func() { fmt.Println(".. in the range 3-6am, 8-11pm") }) c.AddFunc("CRON_TZ=Asia/Tokyo 30 04 * * *", func() { fmt.Println("Runs at 04:30 Tokyo time every day") }) c.AddFunc("@hourly", func() { fmt.Println("Every hour, starting an hour from now") }) c.AddFunc("@every 1h30m", func() { fmt.Println("Every hour thirty, starting an hour thirty from now") }) c.Start() select {} }
Cron表達式格式
一個 cron 表達式表示一組時間,使用 5 個空格分隔的字段。這是v3版本默認支持的格式。
Field name | Mandatory? | Allowed values | Allowed special characters ---------- | ---------- | -------------- | -------------------------- Minutes | Yes | 0-59 | * / , - Hours | Yes | 0-23 | * / , - Day of month | Yes | 1-31 | * / , - ? Month | Yes | 1-12 or JAN-DEC | * / , - Day of week | Yes | 0-6 or SUN-SAT | * / , - ?
如果要想在v3版本中也支持秒級別的解析,需要自定義解析器。代碼如下
Field name | Mandatory? | Allowed values | Allowed special characters ---------- | ---------- | -------------- | -------------------------- Seconds | Yes | 0-59 | * / , - Minutes | Yes | 0-59 | * / , - Hours | Yes | 0-23 | * / , - Day of month | Yes | 1-31 | * / , - ? Month | Yes | 1-12 or JAN-DEC | * / , - Day of week | Yes | 0-6 or SUN-SAT | * / , - ?
func main() { // Seconds field, required cron.New(cron.WithSeconds()) // Seconds field, optional cron.New(cron.WithParser(cron.NewParser( cron.SecondOptional | cron.Minute | cron.Hour | cron.Dom | cron.Month | cron.Dow | cron.Descriptor, ))) }
預定義時間表
可以用@yearly
、@monthly
、@weekly
、@weekly
、@daily
、@hourly
來替代cron表達式。分別表示每年,每月、每星期、每天、每小時。
還可以用@every <duartion>
來表示間隔時間,即間隔<duration>
執行一次任務。<duration>
只要可以被time.ParseDuration()
解析即可
設置時區
func main() { cron.New( cron.WithLocation(time.UTC)) }
常用的方法介紹
New()
package main import ( "fmt" "github.com/robfig/cron/v3" ) func main() { // 創建一個默認的cron對象 c := cron.New() // 自定義解析器 cron.New(cron.WithSeconds()) // Seconds field, optional cron.New(cron.WithParser(cron.NewParser( cron.SecondOptional | cron.Minute | cron.Hour | cron.Dom | cron.Month | cron.Dow | cron.Descriptor, ))) select {} }
AddJob()
// 有兩個參數,第一個參數可以是cron表達式或者預定義時間表,第二個Job func (c *Cron) AddJob(spec string, cmd Job) (EntryID, error) // Job是一個接口,有一個Run方法 type Job interface { Run() }
自定義個一個func類型,實現Run方法。不過一般可以直接用下面講的AddFunc
方法即可
package main import ( "fmt" "github.com/robfig/cron/v3" ) type MyJob func() func (f MyJob) Run() { fmt.Println("myJob") } func main() { c := cron.New() c.AddJob("@every 1s", MyJob(func() { fmt.Println("myjob") })) c.Start() select {}
AddFunc()
// 有兩個參數,第一個參數可以是cron表達式或者預定義時間表,第二個傳入一個函數,就是要執行的任務 // 會返回一個Id和error // 會把傳入的cmd func轉成FuncJob。FuncJob實現了Job接口 func (c *Cron) AddFunc(spec string, cmd func()) (EntryID, error) { return c.AddJob(spec, FuncJob(cmd)) }
package main import ( "fmt" "github.com/robfig/cron/v3" ) func main() { c := cron.New() Id, err := c.AddFunc("30 * * * *", func() { fmt.Println("Every hour on the half hour") }) // Id可以用做取消任務 c.Remove(Id) select {} }
Start()
調用start方法開始執行任務
func main() { c := cron.New() c.AddJob("@every 1s", MyJob(func() { fmt.Println("myjob") })) c.AddFunc() c.Start() select {} }
原文鏈接:https://blog.csdn.net/qq_43058685/article/details/123843956
相關推薦
- 2023-02-10 WPF實現圓形進度條的示例代碼_C#教程
- 2022-11-28 協程作用域概念迭代RxTask?實現自主控制_Android
- 2022-03-27 深入理解C++內聯函數_C 語言
- 2022-10-16 go?swagger生成接口文檔使用教程_Golang
- 2023-01-28 Python多線程與同步機制淺析_python
- 2022-07-28 Python?datacompy?找出兩個DataFrames不同的地方_python
- 2022-08-05 SpringBoot 2.X 整合Redis
- 2021-12-07 Linux系統的修復模式(單用戶模式)_Linux
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支