go語言 robfig/cron包 實現定時 調用


package main
import (
    "github.com/robfig/cron"
    "time"
    "fmt"
    "os"
    log "github.com/cihub/seelog"
)
var (
    ttt int
)
const (
    logFilePath = "hard/log/test/test.log"
)
func init() {
    logLevel := os.Getenv("LOG_LEVEL")
    if logLevel == "" {
        logLevel = "error"
    }
    logger, err := log.LoggerFromConfigAsString(`
    <seelog minlevel="` + logLevel + `" maxlevel="critical">
        <outputs formatid="common">
            <console />
            <rollingfile formatid="common" type="date" datepattern="2006-01-02"  filename="` + logFilePath + `" maxrolls="7"/>
        </outputs>
    
        <formats>
            <format id="common" format="%Date %Time %LEVEL (%File:%Line) - %Msg%n"/>
        </formats>
    </seelog>
    `)
    if err != nil {
        _ = log.Errorf("load seelog config failed! message: %s", err)
    }
    err = log.ReplaceLogger(logger)
    if err != nil {
        _ = log.Error(err)
    }
}
func test(){
    
    fmt.Printf("test=%d\n",ttt)
    ttt++
}
func main() {
    fmt.Println(os.Getenv("GOPATH"))
    ttt=1
    c := cron.New()
    c.AddFunc("0/5 * * * * ?", func() { log.Info("Every hour on the half hour") })
    c.AddFunc("0/5 * * * * ?", test)//5秒執行一次,12×5=60,所以一共執行12次
    c.Start()
    //log.Info("Every hour on the half hour")
    time.Sleep(time.Minute)    //一分鍾后主線程退出
    fmt.Println("aaa")
}
----------------------------------------
package main
import (
    "github.com/robfig/cron"
//    "time"
    "fmt"
    "os"
    log "github.com/cihub/seelog"
)
var (
    ttt int
)
const (
    logFilePath = "D:\\hard/log/test/test.log"
)
func init() {
    logLevel := os.Getenv("LOG_LEVEL")
    if logLevel == "" {
        logLevel = "error"
    }
    logger, err := log.LoggerFromConfigAsString(`
    <seelog minlevel="` + logLevel + `" maxlevel="critical">
        <outputs formatid="common">
            <console />
            <rollingfile formatid="common" type="date" datepattern="2006-01-02"  filename="` + logFilePath + `" maxrolls="7"/>
        </outputs>
    
        <formats>
            <format id="common" format="%Date %Time %LEVEL (%File:%Line) - %Msg%n"/>
        </formats>
    </seelog>
    `)
    if err != nil {
        _ = log.Errorf("load seelog config failed! message: %s", err)
    }
    err = log.ReplaceLogger(logger)
    if err != nil {
        _ = log.Error(err)
    }
}
func test(){
    
    fmt.Printf("test=%d\n",ttt)
    ttt++
}
func main() {
    fmt.Println(os.Getenv("GOPATH"))
    ttt=1
    c := cron.New()
    c.AddFunc("0 33 * * * * ", func() { log.Info("Every hour on the half hour") }) //每小時的第33分鍾調用
    c.AddFunc("0 33 * * * * ", test)
    c.Start()
    //log.Info("Every hour on the half hour")
    select{}
    
}
-------------
func test(){
    log.Error("test")
}
func main() {
    c := cron.New()
    c.AddFunc("@daily", func() { log.Error("Every hour on the half hour") })//每天調用一次
    c.AddFunc("@midnight", test)//每天調用一次(和daily一樣)
    c.Start()    
    log.Info("Every hour on the half hour")
    time.Sleep(time.Minute)
    fmt.Println("aaa")
    select{} //阻塞主線程不退出
}

  

Cron表達式是一個字符串,字符串以5或6個空格隔開,分為6或7個域,每一個域代表一個含義,Cron有如下兩種語法格式:
 
Seconds Minutes Hours DayofMonth Month DayofWeek Year
或:
Seconds Minutes Hours DayofMonth Month DayofWeek
每一個域可出現的字符如下:
Seconds:          可出現     ", - * /"     四個字符,有效范圍為0-59的整數
Minutes:          可出現     ", - * /"     四個字符,有效范圍為0-59的整數
Hours:              可出現     ", - * /"     四個字符,有效范圍為0-23的整數
DayofMonth:  可出現     ", - * / ? L W C"     八個字符,有效范圍為0-31的整數
Month:             可出現     ", - * /"     四個字符,有效范圍為1-12的整數或JAN-DEc
DayofWeek:    可出現     ", - * / ? L C #"     四個字符,有效范圍為1-7的整數或SUN-SAT兩個范圍。1表示星期天,2表示星期一, 依次類推
Year:                 可出現     ", - * /"     四個字符,有效范圍為1970-2099年
每一個域都使用數字,但還可以出現如下特殊字符,它們的含義是:
(1)      *:       表示匹配該域的任意值,假如在Minutes域使用*, 即表示每分鍾都會觸發事件。
(2)      ? :         只能用在DayofMonth和DayofWeek兩個域。它也匹配域的任意值,但實際不會。因為DayofMonth和 DayofWeek會相互影響。例如想在每月的20日觸發調度,不管20日到底是星期幾,則只能使用如下寫法: 13 13 15 20 * ?, 其中最后一位只能用?,而不能使用*,如果使用*表示不管星期幾都會觸發,實際上並不是這樣。
 
(3)      -  :       表示范圍,例如在Minutes域使用5-20,表示從5分到20分鍾每分鍾觸發一次
 
(4)      /:      表示起始時間開始觸發,然后每隔固定時間觸發一次,例如在Minutes域使用5/20,則意味着5分鍾觸發一次,而25,45等分別觸發一次.
 
(5)      , :        表示列出枚舉值值。例如:在Minutes域使用5,20,則意味着在5和20分每分鍾觸發一次。
 
(6)     L:         表示最后,只能出現在DayofWeek和DayofMonth域,如果在DayofWeek域使用5L,意味着在最后的一個星期四觸發。
 
(7)     W:      表示有效工作日(周一到周五),只能出現在DayofMonth域,系統將在離指定日期的最近的有效工作日觸發事件。例如:在 DayofMonth使用5W,如果5日是星期六,則將在最近的工作日:星期五,即4日觸發。如果5日是星期天,則在6日(周一)觸發;如果5日在星期一 到星期五中的一天,則就在5日觸發。另外一點,W的最近尋找不會跨過月份
 
(8)    LW:     這兩個字符可以連用,表示在某個月最后一個工作日,即最后一個星期五。
 

(9)   #:        用於確定每個月第幾個星期幾,只能出現在DayofMonth域。例如在4#2,表示某月的第二個星期三。

 

 

Cron表達式幾個簡單范例:
     每隔5秒執行一次:*/5 * * * * ?
     每隔1分鍾執行一次:0 */1 * * * ?
     每天23點執行一次:0 0 23 * * ?
     每天凌晨1點執行一次:0 0 1 * * ?
     每月1號凌晨1點執行一次:0 0 1 1 * ?
     每月最后一天23點執行一次:0 0 23 L * ?
     每周星期天凌晨1點實行一次:0 0 1 ? * L
     在26分、29分、33分執行一次:0 26,29,33 * * * ?
     每天的0點、13點、18點、21點都執行一次:0 0 0,13,18,21 * * ?


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM