From fc400ad4be030014144ba2132f2799be81b2711e Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期四, 11 七月 2019 14:26:57 +0800
Subject: [PATCH] ---

---
 ruleserver/timeTicker.go |   81 ++++++++++++++++++++++++++++++++++++++++
 1 files changed, 81 insertions(+), 0 deletions(-)

diff --git a/ruleserver/timeTicker.go b/ruleserver/timeTicker.go
new file mode 100644
index 0000000..4b88b14
--- /dev/null
+++ b/ruleserver/timeTicker.go
@@ -0,0 +1,81 @@
+package ruleserver
+
+import (
+	"fmt"
+	"ruleprocess/logger"
+	"time"
+)
+
+var stopChan = make(chan bool)
+
+// 璁℃暟鍣╩ap 鐙珛浠诲姟鐨勯敭鏄换鍔d鎷兼帴鍖哄煙id 鑱斿姩浠诲姟鐨勯敭鏄痝roupid锛堣兘涓嶈兘閮界敤groupId?锛�
+var TimeEleList = make(map[string]*TimeElement)
+
+// 瀹氭椂鍣ㄥ厓绱�
+type TimeElement struct {
+	N            int      // 鎸夋椂闂翠緷娆¢�掑噺鐨勫綋鍓嶅��
+	InitN        int      // 璧嬪�煎悗灏变笉鍙樼殑鍒濆鍊�
+	AlarmFlag	 bool	  // 鎶ヨ鏍囧織浣� 瀹氭椂鍣ㄥ紑鍚悗绗竴娆℃姤璀︽椂浼氳缃负true 寰�鍚庡啀鏉ユ姤璀︿篃涓嶄細鎻掕繘ES
+	CacheSdkData SdkDatas // 瀹氭椂鍣ㄧ殑缂撳瓨鏁版嵁 鎸佺画鏃堕棿绫荤殑寮�鍚畾鏃跺櫒鏃惰缂撳瓨涓�甯�
+	GroupId      string   // 鑱斿姩瑙勫垯闇�瑕佽褰曚笅姝ゆ椂鐨勮鍒欑粍id
+	RuleResults  []*RuleResult
+}
+type RuleResult struct {
+	// 姣忎釜鎽勫儚鏈轰竴涓粨鏋勪綋
+	CameraId    string // 鎽勫儚鏈篿d
+	Sort        int32  // 鎽勫儚鏈哄湪瑙勫垯缁勪腑搴忓彿
+	Result      string // 鎽勫儚鏈鸿繃婊ゆ暟鎹緱鍑虹殑缁撴灉
+	RuleWithPre string // 鎽勫儚鏈轰箣闂寸殑杩炴帴绗�
+}
+
+func TimeTicker() {
+	logger.Info("瀹氭椂鍣ㄦ墽琛屼簡")
+	fmt.Println("瀹氭椂鍣ㄦ墽琛屼簡")
+	ticker := time.NewTicker(1 * time.Second)
+	go func(ticker *time.Ticker) {
+		defer ticker.Stop()
+		for {
+			select {
+			case <-ticker.C:
+				logger.Info("瀹氭椂鍣ㄦ墽琛屽崟鍏�", time.Now().Unix())
+				fmt.Println("瀹氭椂鍣ㄦ墽琛屽崟鍏�", time.Now().Unix())
+				// 姣忕閽熻鏁板櫒姹犲瓙閲屾墍鏈夌殑璁℃暟鍣ㄥ厓绱犻兘鍑忎竴锛屽噺鍒�0鐨勬槸璇ユ姤璀︾殑
+				for k, timeEle := range TimeEleList {
+					if timeEle.N > 0 {
+						timeEle.N = timeEle.N - 1
+						logger.Info("-------------------------------------鎵撳嵃瀹氭椂鍣ㄥ厓绱犲綋鍓嶅��-----------------------------------------锛�", timeEle.N)
+					}
+					if timeEle.GroupId != "" && timeEle.N == 0{
+						// 璇存槑鏄仈鍔ㄤ换鍔$殑鏃堕棿绐楀彛 鍒扮偣鍎夸簡璇ラ攢姣佷簡,鍐嶆潵浜嗗啀鍒涘缓
+						delete(TimeEleList,k)
+					}
+				}
+			case stop := <-stopChan:
+				if stop {
+					logger.Info("瀹氭椂鍣ㄧ粨鏉�")
+					return
+					//os.Exit(0)
+				}
+			}
+		}
+	}(ticker)
+}
+func StopTimeTicker() {
+	stopChan <- true
+	TimeTicker()
+}
+
+
+// 缁撴瀯浣撴牴鎹煇瀛楁鎺掑簭
+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 }

--
Gitblit v1.8.0