panlei
2019-09-27 5fb11ccf2dbdf3ae51586667b202b7c03c5fa9cb
ruleserver/timeTicker.go
@@ -2,7 +2,7 @@
import (
   "fmt"
   "ruleprocess/logger"
   "basic.com/valib/logger.git"
   "strings"
   "time"
)
@@ -32,17 +32,16 @@
}
func TimeTicker() {
   //logger.Info("定时器执行了")
   //fmt.Println("定时器执行了")
   ticker := time.NewTicker(1 * time.Second)
   //go func(ticker *time.Ticker) {
   //   defer ticker.Stop()
   go func(ticker *time.Ticker) {
      defer ticker.Stop()
      for {
         select {
         case <-ticker.C:
            logger.Info("定时器执行单元", time.Now().Unix())
            fmt.Println("定时器执行单元", time.Now().Unix())
            // 每秒钟计数器池子里所有的计数器元素都减一,减到0的是该报警的
            rw.Lock()
            for k, timeEle := range TimeEleList {
               if timeEle.N > 0 {
                  timeEle.N = timeEle.N - 1
@@ -53,6 +52,7 @@
                  delete(TimeEleList, k)
               }
            }
            rw.Unlock()
         case stop := <-stopChan:
            if stop {
               logger.Info("定时器结束")
@@ -61,7 +61,7 @@
            }
         }
      }
   //}(ticker)
   }(ticker)
}
func StopTimeTicker() {
   stopChan <- true
@@ -73,6 +73,7 @@
   var flagTime string //
   // 判断有无此规则组的定时器
   flag := false
   rw.Lock()
   for k, _ := range TimeEleList {
      //logger.Debug("-----------------看看这个key和groupId", k, groupId)
      if strings.Contains(k, groupId) && k != groupId{
@@ -134,6 +135,7 @@
         flagTime = "00"
      }
   }
   rw.Unlock()
   return flagTime
}