From 6b126815f07969ef830f1828edf07f1a0af72676 Mon Sep 17 00:00:00 2001 From: panlei <2799247126@qq.com> Date: 星期六, 02 十一月 2019 17:57:51 +0800 Subject: [PATCH] --- --- labelFilter/ruleForLabel.go | 40 +++++++++++++++++++++++++++++----------- 1 files changed, 29 insertions(+), 11 deletions(-) diff --git a/labelFilter/ruleForLabel.go b/labelFilter/ruleForLabel.go index ba8cbd0..b4c0b32 100644 --- a/labelFilter/ruleForLabel.go +++ b/labelFilter/ruleForLabel.go @@ -3,14 +3,21 @@ import ( "basic.com/dbapi.git" "basic.com/pubsub/protomsg.git" + "basic.com/valib/logger.git" + "github.com/golang/protobuf/proto" "github.com/knetic/govaluate" - "ruleprocess/logger" - "ruleprocess/ruleserver" + "ruleprocess/structure" "strconv" "time" ) -func Judge(msg ruleserver.ResultMsg) { +func PushSomthing(msg structure.ResultMsg) { + defer func() { + if err := recover(); err != nil { + logger.Error("浜嬩欢鎺ㄩ�佹ā鍧楀効鐨勫紓甯告崟鑾凤細",err) + } + }() + // 瑁呴厤鎴愯嚜宸卞彲浠ヨ瘑鍒殑鏁版嵁 label := new(Label) label.DataFormatToLabel(msg) @@ -33,7 +40,7 @@ timeFlag := timeJudge(label, ruleGroup) if !timeFlag { logger.Info("涓嶅湪瑙勫垯鐨勬椂闂磋寖鍥村唴锛屼笉鎺ㄩ�侊紒") - return + continue } result := "" var Connector string @@ -67,6 +74,7 @@ expression, err := govaluate.NewEvaluableExpression(result); if err != nil { logger.Error("琛ㄨ揪寮忔湁璇紝璇锋鏌ワ紒") + return } result, err1 := expression.Evaluate(nil) if err1 != nil { @@ -107,6 +115,7 @@ expression, err := govaluate.NewEvaluableExpression("t1 < t2"); if err != nil { logger.Error("琛ㄨ揪寮忔湁璇紝璇锋鏌ワ紒") + return false } parameters := make(map[string]interface{}, 8) parameters["t1"] = time1 @@ -167,7 +176,7 @@ logger.Info("-------鎵撳嵃搴曞簱瑙勫垯鍏紡锛�",formula) if err != nil { logger.Error("琛ㄨ揪寮忔湁璇紝璇锋鏌ワ紒", formula) - //return "false" + return "false" } result, err1 := expression.Evaluate(nil) if err1 != nil { @@ -208,7 +217,7 @@ expression, err := govaluate.NewEvaluableExpression(formula); if err != nil { logger.Error("琛ㄨ揪寮忔湁璇紝璇锋鏌ワ紒", formula) - //return "false" + return "false" } result, err1 := expression.Evaluate(nil) if err1 != nil { @@ -232,7 +241,7 @@ expression, err := govaluate.NewEvaluableExpression(formula); if err != nil { logger.Error("琛ㄨ揪寮忔湁璇紝璇锋鏌ワ紒", formula) - //return "false" + return "false" } result, err1 := expression.Evaluate(nil) if err1 != nil { @@ -264,12 +273,12 @@ } } else { for _, def := range label.DefenceLevel { - formula := strconv.Itoa(int(def)) + rule.Operator + formate(rule.RuleValue) + formula := strconv.Itoa(int(def)) + rule.Operator + rule.RuleValue logger.Info("-------鎵撳嵃甯冮槻绛夌骇瑙勫垯鍏紡锛�",formula) expression, err := govaluate.NewEvaluableExpression(formula); if err != nil { logger.Error("琛ㄨ揪寮忔湁璇紝璇锋鏌ワ紒", formula) - //return "false" + return "false" } result, err1 := expression.Evaluate(nil) if err1 != nil { @@ -309,10 +318,19 @@ } // 璋冪敤鐩爣鏈嶅姟鍣ㄧ殑鎻掑叆鎺ュ彛 -func pushData(urls []*protomsg.PushUrl, data ruleserver.ResultMsg) { +func pushData(urls []*protomsg.PushUrl, data structure.ResultMsg) { for _, url := range urls { logger.Debug("鐪嬬湅鎺ㄩ�佸湴鍧�锛�",url.Url) - Push("tcp://192.168.1.123:40012", data) + bytes,err1 := proto.Marshal(data) + if err1 != nil { + logger.Info("搴忓垪鍖栧け璐ワ細",err1) + } + if _, ok := urlPool[url.Url] ; ok { + urlPool[url.Url] <- bytes + logger.Info("chan淇℃伅鑰岋細 ", urlPool[url.Url]) + } + logger.Info("chan淇℃伅浠ワ細 ", urlPool[url.Url]) + } } -- Gitblit v1.8.0