panlei
2019-07-10 45184ccbcb5f787f09b62b0ddf4308004a46d27a
ruleserver/timeTicker.go
@@ -2,7 +2,7 @@
import (
   "fmt"
   "os"
   "ruleprocess/logger"
   "time"
)
@@ -27,6 +27,7 @@
}
func TimeTicker() {
   logger.Info("定时器执行了")
   fmt.Println("定时器执行了")
   ticker := time.NewTicker(1 * time.Second)
   go func(ticker *time.Ticker) {
@@ -34,17 +35,20 @@
      for {
         select {
         case <-ticker.C:
            fmt.Println("定时器执行单元")
            logger.Info("定时器执行单元",time.Now().Unix())
            fmt.Println("定时器执行单元",time.Now().Unix())
            // 每秒钟计数器池子里所有的计数器元素都减一,减到0的是该报警的
            for _, timeEle := range TimeEleList {
               if timeEle.N > 0 {
                  timeEle.N = timeEle.N - 1
                  logger.Info("-------------------------------------打印定时器元素当前值-----------------------------------------:",timeEle.N)
               }
            }
         case stop := <-stopChan:
            if stop {
               fmt.Println("定时器结束")
               os.Exit(0)
               logger.Info("定时器结束")
               return
               //os.Exit(0)
            }
         }
      }
@@ -57,7 +61,7 @@
// 定时器单元  废弃版本
// func TimeTicker() chan bool {
//    fmt.Println("执行了timeTicker")
//    logger.Info("执行了timeTicker")
//    ticker := time.NewTicker(1 * time.Second)
//    stopChan := make(chan bool)
//    go func(ticker *time.Ticker) {
@@ -65,10 +69,10 @@
//       for {
//          select {
//          case <-ticker.C:
//             //fmt.Println("执行单元", "计数器集合2", TimeEleList)
//             //logger.Info("执行单元", "计数器集合2", TimeEleList)
//             for k, timeEle := range TimeEleList {
//                timeEle.n = timeEle.n - 1
//                //fmt.Println("遍历的数值", TimeEleList)
//                //logger.Info("遍历的数值", TimeEleList)
//                if timeEle.n == 0 {
//                   // do something alarm
//                   alarm(k, timeEle)
@@ -76,7 +80,7 @@
//             }
//          case stop := <-stopChan:
//             if stop {
//                fmt.Println("定时器结束")
//                logger.Info("定时器结束")
//                return
//             }
//          }
@@ -85,8 +89,17 @@
//    return stopChan
// }
// 结构体根据某字段排序
type SubList []*RuleResult
func (p SubList) Swap(i, j int)      { p[i], p[j] = p[j], p[i] }
func (p SubList) Len() int           { return len(p) }
func (p SubList) Less(i, j int) bool { return p[i].Sort < p[j].Sort }
// 结构体根据某字段排序
type resultList []*LittleRuleResult
func (p resultList) Swap(i, j int)      { p[i], p[j] = p[j], p[i] }
func (p resultList) Len() int           { return len(p) }
func (p resultList) Less(i, j int) bool { return p[i].Sort < p[j].Sort }