From f800147e68f2831ef3233555b7e2b3499b35bc5e Mon Sep 17 00:00:00 2001 From: panlei <2799247126@qq.com> Date: 星期一, 09 十二月 2019 14:28:32 +0800 Subject: [PATCH] 切回原来日志包 --- labelFilter/ruleForLabel.go | 86 +++++++++++++++++++++++++++--------------- 1 files changed, 55 insertions(+), 31 deletions(-) diff --git a/labelFilter/ruleForLabel.go b/labelFilter/ruleForLabel.go index 1adf9ce..17c5015 100644 --- a/labelFilter/ruleForLabel.go +++ b/labelFilter/ruleForLabel.go @@ -3,18 +3,25 @@ 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) + } + }() + start := time.Now() // 瑁呴厤鎴愯嚜宸卞彲浠ヨ瘑鍒殑鏁版嵁 label := new(Label) label.DataFormatToLabel(msg) - logger.Info("label鐨勪俊鎭細", label.CameraName, label.DefenceLevel, label.Time) + //logger.Info("label鐨勪俊鎭細", label.CameraName, label.DefenceLevel, label.Time) if label.CameraName == "" { logger.Error("鏃犳晥鏁版嵁锛岀洿鎺ヨ繑鍥�") return @@ -22,7 +29,7 @@ //鎷垮埌鎵�鏈夎鍒欑粍 var api dbapi.EventPushApi b, allRules := api.FindAllDetails() - logger.Info("鏌ョ湅鎵�鏈夎鍒欑粍锛�", allRules) + //logger.Info("鏌ョ湅鎵�鏈夎鍒欑粍锛�", allRules) if !b { logger.Error("鏌ヨ鏃堕棿鎺ㄩ�佽鍒欏け璐ワ紒") } @@ -33,7 +40,7 @@ timeFlag := timeJudge(label, ruleGroup) if !timeFlag { logger.Info("涓嶅湪瑙勫垯鐨勬椂闂磋寖鍥村唴锛屼笉鎺ㄩ�侊紒") - return + continue } result := "" var Connector string @@ -45,19 +52,19 @@ for _, rule := range ruleGroup.Rules { // 杩囨瘡涓�涓皬瑙勫垯 if rule.TopicType == "camera" { - result = Connector + cameraJudge(label, rule) + result += Connector + cameraJudge(label, rule) } if rule.TopicType == "dbtable" { - result = Connector + baseJudge(label, rule) + result += Connector + baseJudge(label, rule) } if rule.TopicType == "task" { - result = Connector + taskJudge(label, rule) + result += Connector + taskJudge(label, rule) } if rule.TopicType == "person" { - result = Connector + taskJudge(label, rule) + result += Connector + taskJudge(label, rule) } if rule.TopicType == "alarmLevel" { - result = Connector + defenceJudge(label, rule) + result += Connector + defenceJudge(label, rule) } } // 寰楀嚭鎬荤殑鍒ゆ柇缁撴灉 @@ -67,6 +74,7 @@ expression, err := govaluate.NewEvaluableExpression(result); if err != nil { logger.Error("琛ㄨ揪寮忔湁璇紝璇锋鏌ワ紒") + return } result, err1 := expression.Evaluate(nil) if err1 != nil { @@ -76,6 +84,7 @@ logger.Info("閫氳繃瑙勫垯锛岃〃杈惧紡涓猴細", result) // 鎺ㄩ�佹湇鍔″櫒 pushData(ruleGroup.Urls, msg) + logger.Info("鏃堕棿鎺ㄩ�佹墍鐢ㄦ椂闂达細",time.Since(start)) //os.Exit(1) } else { logger.Info("娌¢�氳繃瑙勫垯,琛ㄨ揪寮忎负锛�", result) @@ -91,7 +100,7 @@ // 鏄惁绗﹀悎鏃堕棿瑙勫垯 func timeJudge(label *Label, groupRule protomsg.EventPush) bool { timeNow := time.Now().Format("2006-01-02 15:04:05") - logger.Info("鏍囩杩囨护鍣ㄨ捣濮嬫椂闂翠负锛�",groupRule.TimeStart,groupRule.TimeEnd) + //logger.Info("鏍囩杩囨护鍣ㄨ捣濮嬫椂闂翠负锛�",groupRule.TimeStart,groupRule.TimeEnd) flag1 := isBefore(groupRule.TimeStart, timeNow) flag2 := isBefore(timeNow, groupRule.TimeEnd) if flag1 && flag2 { @@ -107,6 +116,7 @@ expression, err := govaluate.NewEvaluableExpression("t1 < t2"); if err != nil { logger.Error("琛ㄨ揪寮忔湁璇紝璇锋鏌ワ紒") + return false } parameters := make(map[string]interface{}, 8) parameters["t1"] = time1 @@ -127,6 +137,7 @@ if rule.TopicArg == "addr" { formula = "'" + label.CameraAddr + "'" + rule.Operator + "'" + rule.RuleValue + "'" } + //logger.Info("-------鎵撳嵃鎽勫儚鏈鸿鍒欏叕寮忥細",formula) expression, err := govaluate.NewEvaluableExpression(formula); if err != nil { logger.Error("琛ㄨ揪寮忔湁璇紝璇锋鏌ワ紒", formula) @@ -141,7 +152,7 @@ logger.Info("绗﹀悎鎽勫儚鏈鸿鍒�!") return "true" } - logger.Info("涓嶇鍚堟憚鍍忔満瑙勫垯!") + //logger.Info("涓嶇鍚堟憚鍍忔満瑙勫垯!") return "false" } @@ -149,7 +160,7 @@ func baseJudge(label *Label, rule *protomsg.EventPushRule) string { if rule.RuleValue == "all" { for _, personGroup := range label.Persons { - for _, arg := range personGroup.Args { + for _, arg := range personGroup.AlarmObj { if len(arg.Liker) > 0 { logger.Info("婊¤冻鍏ㄩ儴搴曞簱瑙勫垯") return "true" @@ -159,13 +170,14 @@ return "false" } else { for _, personGroup := range label.Persons { - for _, arg := range personGroup.Args { + for _, arg := range personGroup.AlarmObj { for _, liker := range arg.Liker { formula := "'" + liker.TableId + "'" + rule.Operator + "'" + rule.RuleValue + "'" expression, err := govaluate.NewEvaluableExpression(formula); + //logger.Info("-------鎵撳嵃搴曞簱瑙勫垯鍏紡锛�",formula) if err != nil { logger.Error("琛ㄨ揪寮忔湁璇紝璇锋鏌ワ紒", formula) - //return "false" + return "false" } result, err1 := expression.Evaluate(nil) if err1 != nil { @@ -187,7 +199,7 @@ //鏄惁绗﹀悎浜哄憳瑙勫垯 func personJudge(label *Label, rule *protomsg.EventPushRule) string { for _, personGroup := range label.Persons { - for _, person := range personGroup.Args { + for _, person := range personGroup.AlarmObj { formula := "" if rule.TopicArg == "sex" { formula = strconv.Itoa(int(person.ThftRes.Gender)) + rule.Operator + rule.RuleValue @@ -202,10 +214,11 @@ // 鍏朵粬杩欎釜鍊煎厛杩欎箞澶勭悊 return "true" } + //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 { @@ -219,16 +232,17 @@ } if rule.TopicArg == "monitorLevel" { if rule.RuleValue == "all" { - if len(personGroup.Args) > 0 { + if len(personGroup.AlarmObj) > 0 { logger.Info("绗﹀悎浜哄憳绛夌骇涓哄叏閮ㄧ殑瑙勫垯") return "true" } } else { formula := strconv.Itoa(int(personGroup.AlarmLevel)) + rule.Operator + formate(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 { @@ -252,19 +266,20 @@ func defenceJudge(label *Label, rule *protomsg.EventPushRule) string { if rule.RuleValue == "all" { // 甯冮槻绛夌骇涓哄叏閮ㄦ椂鍙湁鏈夊竷闃茬瓑绾у嵆涓洪�氳繃 if len(label.DefenceLevel) > 0 { - logger.Info("绗﹀悎甯冮槻绛夌骇瑙勫垯锛屽竷闃茬瓑绾т负鍏ㄩ儴") + //logger.Info("绗﹀悎甯冮槻绛夌骇瑙勫垯锛屽竷闃茬瓑绾т负鍏ㄩ儴") return "true" } else { - logger.Info("涓嶇鍚堝竷闃茬瓑绾ц鍒�") + //logger.Info("涓嶇鍚堝竷闃茬瓑绾ц鍒�") return "false" } } 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 { @@ -272,11 +287,11 @@ //return "false" } if result.(bool) { - logger.Info("绗﹀悎甯冮槻绛夌骇瑙勫垯!") + //logger.Info("绗﹀悎甯冮槻绛夌骇瑙勫垯!") return "true" } } - logger.Info("涓嶇鍚堝竷闃茬瓑绾ц鍒�") + //logger.Info("涓嶇鍚堝竷闃茬瓑绾ц鍒�") return "false" } } @@ -285,6 +300,7 @@ func taskJudge(label *Label, rule *protomsg.EventPushRule) string { formula := "'"+label.TaskId +"'"+ rule.Operator +"'"+ rule.RuleValue+"'" expression, err := govaluate.NewEvaluableExpression(formula); + //logger.Info("-------鎵撳嵃浠诲姟瑙勫垯鍏紡锛�",formula) if err != nil { logger.Error("琛ㄨ揪寮忔湁璇紝璇锋鏌ワ紒", formula) return "false" @@ -295,19 +311,27 @@ return "false" } if result.(bool) { - logger.Info("绗﹀悎浠诲姟瑙勫垯!") + //logger.Info("绗﹀悎浠诲姟瑙勫垯!") return "true" } - logger.Info("涓嶇鍚堜换鍔¤鍒�") + //logger.Info("涓嶇鍚堜换鍔¤鍒�") return "false" } // 璋冪敤鐩爣鏈嶅姟鍣ㄧ殑鎻掑叆鎺ュ彛 -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) + //logger.Debug("鎺ㄩ�佸湴鍧�锛�",url.Url) + bytes,err1 := proto.Marshal(data) + if err1 != nil { + logger.Info("搴忓垪鍖栧け璐ワ細",err1) + } + if _, ok := urlPool[url.Url] ; ok { + urlPool[url.Url] <- bytes + } + } + } // 鎶婃姤璀︾瓑绾ц浆鍖栨垚姹夊瓧 -- Gitblit v1.8.0