From 43876595ecbbf6c41fafc8293713347e8ed4014d Mon Sep 17 00:00:00 2001 From: panlei <2799247126@qq.com> Date: 星期六, 13 七月 2019 15:04:15 +0800 Subject: [PATCH] 定时器缓存数据分类插入 --- insertdata/insertDataToEs.go | 578 +++++++++++++++++++++++++++++----------------------- ruleserver/ruleToformula.go | 33 +- main.go | 4 ruleserver/timeTicker.go | 17 4 files changed, 352 insertions(+), 280 deletions(-) diff --git a/insertdata/insertDataToEs.go b/insertdata/insertDataToEs.go index 5215589..c2e4fee 100644 --- a/insertdata/insertDataToEs.go +++ b/insertdata/insertDataToEs.go @@ -1,32 +1,35 @@ package insertdata import ( - "ruleprocess/logger" "encoding/json" "errors" "fmt" "io/ioutil" "net" "ruleprocess/cache" + "ruleprocess/logger" "strings" "time" "basic.com/pubsub/protomsg.git" + "github.com/go-yaml/yaml" "github.com/golang/protobuf/proto" "github.com/satori/go.uuid" "ruleprocess/ruleserver" "ruleprocess/util" - "github.com/go-yaml/yaml" ) + var weedfsUrl string + type conf struct { PhotoUrl string `yaml:"photoUrl"` } + func init() { data, err := ioutil.ReadFile("./config/conf.yml") if err != nil { - fmt.Println("璇诲彇閰嶇疆鏂囦欢鍑洪敊--",err) - logger.Error("璇诲彇閰嶇疆鏂囦欢鍑洪敊--",err) + fmt.Println("璇诲彇閰嶇疆鏂囦欢鍑洪敊--", err) + logger.Error("璇诲彇閰嶇疆鏂囦欢鍑洪敊--", err) } c := conf{} //鎶妝aml褰㈠紡鐨勫瓧绗︿覆瑙f瀽鎴恠truct绫诲瀷 @@ -36,35 +39,35 @@ // 浜鸿劯鐨勬暟鎹粨鏋� type PerVideoPicture struct { - Id string `json:"id"` - CameraId string `json:"cameraId"` - CameraAddr string `json:"cameraAddr"` - PicDate string `json:"picDate"` - PicMaxUrl string `json:"picMaxUrl"` - TaskId string `json:"taskId"` - TaskName string `json:"taskName"` - SdkName string `json:"sdkName"` - Content string `json:"content"` - LikeDate string `json:"likeDate"` - Sex string `json:"sex"` - Age int32 `json:"age"` - AgeDescription string `json:"ageDescription"` - Race string `json:"race"` - SmileLevel int32 `json:"smileLevel"` - BeautyLevel int32 `json:"beautyLevel"` - FaceFeature string `json:"faceFeature"` - PicSmUrl []string `json:"picSmUrl"` - VideoUrl string `json:"videoUrl"` - AnalyServerId string `json:"analyServerId"` - AnalyServerName string `json:"analyServerName"` - AnalyServerIp string `json:"analyServerIp"` - ClusterId string `json:"clusterId"` - DetectScore float64 `json:"detectScore"` - IsAlarm int `json:"isAlarm"` - IsAckAlarm int `json:"isAckAlarm"` - IsCollect int `json:"isCollect"` - IsDelete int `json:"isDelete"` - BaseInfo []*protomsg.Baseinfo `json:"baseInfo"` + Id string `json:"id"` + CameraId string `json:"cameraId"` + CameraAddr string `json:"cameraAddr"` + PicDate string `json:"picDate"` + PicMaxUrl string `json:"picMaxUrl"` + TaskId string `json:"taskId"` + TaskName string `json:"taskName"` + SdkName string `json:"sdkName"` + Content string `json:"content"` + LikeDate string `json:"likeDate"` + Sex string `json:"sex"` + Age int32 `json:"age"` + AgeDescription string `json:"ageDescription"` + Race string `json:"race"` + SmileLevel int32 `json:"smileLevel"` + BeautyLevel int32 `json:"beautyLevel"` + FaceFeature string `json:"faceFeature"` + PicSmUrl []string `json:"picSmUrl"` + VideoUrl string `json:"videoUrl"` + AnalyServerId string `json:"analyServerId"` + AnalyServerName string `json:"analyServerName"` + AnalyServerIp string `json:"analyServerIp"` + ClusterId string `json:"clusterId"` + DetectScore float64 `json:"detectScore"` + IsAlarm int `json:"isAlarm"` + IsAckAlarm int `json:"isAckAlarm"` + IsCollect int `json:"isCollect"` + IsDelete int `json:"isDelete"` + BaseInfo []*protomsg.Baseinfo `json:"baseInfo"` } // yolo琛屼负鐨勬暟鎹粨鏋� @@ -100,266 +103,331 @@ // 寰�ES鎻掓暟鎹� func InsertToEs(msg ruleserver.ResultMsg) { var timeLabel string - // 鐩存帴浠庤鍒欑殑鏍囩鏁版嵁閲屾嬁绗﹀悎瑙勫垯鐨勪汉鑴哥粨鏋� + // 鐩存帴浠庤鍒欑殑鏍囩鏁版嵁閲屾嬁绗﹀悎瑙勫垯鐨勪汉鑴哥粨鏋� if msg.RuleResult["timeLabel"] != nil { timeLabel = msg.RuleResult["timeLabel"].(string) } - logger.Debug("鎻掑叆鏁版嵁鍓嶇湅鐪嬫姤璀︽爣蹇椾綅锛�",timeLabel) - if timeLabel == "10" { - if msg.RuleResult["face"] != nil && len(msg.RuleResult["face"].([]ruleserver.Arg)) > 0 { - logger.Info("寰�ES鎻掍汉鑴告暟鎹�") - for _, face := range msg.RuleResult["face"].([]ruleserver.Arg) { - // 涓婁紶澶у浘 - // 瑙e帇缂╁苟涓婁紶鍥剧墖 - bdata, err := util.UnCompress(msg.Data) - if err != nil { - panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒") - } - i := protomsg.Image{} - err = proto.Unmarshal(bdata, &i) - bigPhotoUrl := make(map[string]interface{}) - bigPhotoUrl, err = util.PostFormBufferData(weedfsUrl, i, uuid.NewV4().String()) - logger.Info(bigPhotoUrl) - if len(face.Liker) == 0 { - // 浜鸿劯妫�娴嬶紝娌℃湁鐩镐技鐨勫簳搴撲汉鍛� - localConfig, err := cache.GetServerInfo() - if err != nil { - logger.Error("鏌ヨ鏈満淇℃伅澶辫触锛�") - } - serverIp, err := GetLocalIP() - // 瑙e帇缂╁苟涓婁紶鍥剧墖 - bdata, err := util.UnCompress(msg.Data) - if err != nil { - panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒") - } - // 鏌ヨcameraName - camera, err := cache.GetCameraById(msg.Cid) - if err != nil { - logger.Error("鏌ヨ鎽勫儚鏈轰俊鎭け璐�") - } - i := protomsg.Image{} - err = proto.Unmarshal(bdata, &i) - bytes := util.SubImg(i, int(face.Location.X), int(face.Location.Y), int(face.Location.X+face.Location.Width), int(face.Location.Y+face.Location.Height)) - resp, err := util.PostFormBufferData1(weedfsUrl, bytes, uuid.NewV4().String()) - if err != nil { - logger.Error("涓婁紶灏忓浘鍑洪敊") - } - logger.Info("================灏忓浘鍦板潃:",resp["fileUrl"].(string)) - sex := "" - if face.ThftRes.Gender == 1 { - sex = "鐢�" - } else { - sex = "濂�" - } - race := getRaceString(face.ThftRes.Race) - ageDescription := getDescription(face.ThftRes.Age) + logger.Debug("鎻掑叆鏁版嵁鍓嶇湅鐪嬫姤璀︽爣蹇椾綅锛�", timeLabel) + if timeLabel == "01" { // 鏃犲畾鏃跺櫒鐘舵�佽鎻掑叆鐨勬姤璀︽暟鎹� + InsertFace(msg) + InsertYolo(msg) + } + if timeLabel == "10" { // 瀹氭椂鍣ㄧ姸鎬佽鎻掑叆鐨勯甯ф姤璀︽暟鎹�傝繛甯︾潃瀹氭椂鍣ㄥ紑鍚椂鐨勯偅甯� + InsertFace(msg) + InsertFace(msg.RuleResult["cacheData"].(ruleserver.ResultMsg)) + InsertYolo(msg) + InsertYolo(msg.RuleResult["cacheData"].(ruleserver.ResultMsg)) + } + if timeLabel == "12" { // 骞堕潪鎶ヨ鏁版嵁锛屽彧鏄姸鎬佹敼鍙樼殑鏁版嵁 + ChangeStatusFace(msg) + ChangeStatusYolo(msg) + } +} - pervideo := PerVideoPicture{ - uuid.NewV4().String(), - msg.Cid, - camera.Addr, - time.Now().Format("2006-01-02 15:04:05"), - strings.Split(bigPhotoUrl["fileUrl"].(string), "/")[1], - msg.Tasklab.Taskid, - msg.Tasklab.Taskname, - "浜鸿劯", - "", - time.Now().Format("2006-01-02 15:04:05"), // 鍙娴嬶紝娌℃湁姣斿鏃堕棿 - sex, - face.ThftRes.Age, - ageDescription, - race, - face.ThftRes.Smile, - face.ThftRes.Beauty, - string(face.Feature), - []string{strings.Split(resp["fileUrl"].(string), "/")[1]}, - "鏆傛棤闆嗙兢", - localConfig.ServerId, - localConfig.ServerName, - serverIp, - "", - face.Score, - 1, - 0, - 0, - 0, - []*protomsg.Baseinfo{}, - } - requstbody, err := json.Marshal(pervideo) - - if err != nil { - logger.Info("json parse error ", err) - return - - } - err1 := EsReq("POST", "http://192.168.1.182:9200/videopersons/perVideoPicture", requstbody) - if err1 != nil { - logger.Error("涓婁紶ES鍑洪敊锛�---",err1) - } - //logger.Info(err.Error()) - } else { - // 浜鸿劯姣斿 - logger.Warn("___________________________________________杩欐槸鏈塨aseinfo鐨�") - localConfig, err := cache.GetServerInfo() - if err != nil { - logger.Info("鏌ヨ鏈満淇℃伅澶辫触锛�") - } - serverIp, err := GetLocalIP() - // 瑙e帇缂╁苟涓婁紶鍥剧墖 - bdata, err := util.UnCompress(msg.Data) - if err != nil { - panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒") - } - // 鏌ヨcameraName - camera, err := cache.GetCameraById(msg.Cid) - if err != nil { - logger.Error("鏌ヨ鎽勫儚鏈轰俊鎭け璐�") - } - i := protomsg.Image{} - err = proto.Unmarshal(bdata, &i) - //logger.Info("-------------------------------------------鐪嬩笅瀹藉拰楂�", i.Width, i.Height) - bytes := util.SubImg(i, int(face.Location.X), int(face.Location.Y), int(face.Location.X+face.Location.Width), int(face.Location.Y+face.Location.Height)) - resp, err := util.PostFormBufferData1(weedfsUrl, bytes, uuid.NewV4().String()) - if err != nil { - logger.Error("涓婁紶灏忓浘鍑洪敊") - } - logger.Info("================灏忓浘鍦板潃:",resp["fileUrl"].(string)) - sex := "" - if face.ThftRes.Gender == 1 { - sex = "鐢�" - } else { - sex = "濂�" - } - race := getRaceString(face.ThftRes.Race) - ageDescription := getDescription(face.ThftRes.Age) - pervideo := PerVideoPicture{ - uuid.NewV4().String(), - msg.Cid, - camera.Addr, - time.Now().Format("2006-01-02 15:04:05"), - strings.Split(bigPhotoUrl["fileUrl"].(string), "/")[1], - msg.Tasklab.Taskid, - msg.Tasklab.Taskname, - "浜鸿劯", - "", - time.Now().Format("2006-01-02 15:04:05"), // 鍙娴嬶紝娌℃湁姣斿鏃堕棿 - sex, - face.ThftRes.Age, - ageDescription, - race, - face.ThftRes.Smile, - face.ThftRes.Beauty, - "", - []string{strings.Split(resp["fileUrl"].(string), "/")[1]}, - "鏆傛棤闆嗙兢", - localConfig.ServerId, - localConfig.ServerName, - serverIp, - "", - face.Score, - 1, - 0, - 0, - 0, - face.Liker, - } - requstbody, err := json.Marshal(pervideo) - - if err != nil { - logger.Error("json parse error ", err) - return - - } - err = EsReq("POST", "http://192.168.1.182:9200/videopersons/perVideoPicture", requstbody) - logger.Info("------------------------------------------鍝堝搱鍝堝搱锛屽簳搴撴湁浜�") - - } +// 寰�es涓彃鍏ヤ汉鑴告暟鎹� +func InsertFace(msg ruleserver.ResultMsg) { + if msg.RuleResult["face"] != nil && len(msg.RuleResult["face"].([]ruleserver.Arg)) > 0 { + logger.Info("寰�ES鎻掍汉鑴告暟鎹�") + for _, face := range msg.RuleResult["face"].([]ruleserver.Arg) { + // 涓婁紶澶у浘 + // 瑙e帇缂╁苟涓婁紶鍥剧墖 + bdata, err := util.UnCompress(msg.Data) + if err != nil { + panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒") } - } - if msg.RuleResult["yolo"] != nil && len(msg.RuleResult["yolo"].([]ruleserver.Result)) > 0 { - logger.Info("寰�ES鎻抷olo鏁版嵁") - var sdkNames string = "" - alarmRules := []AlarmRule{} - for _, yoloResult := range msg.RuleResult["yolo"].([]ruleserver.Result) { - sdkNames = sdkNames + yoloResult.SdkName - alarm := ChangeToString(yoloResult.AlarmLevel) - alarmRules = append(alarmRules, AlarmRule{yoloResult.RuleGroupId, alarm, yoloResult.RuleText}) - } - isAlarm := 0 - resp := make(map[string]interface{}) - if len(alarmRules) > 0 { - isAlarm = 1 - // 瑙e帇缂╁苟涓婁紶鍥剧墖 - bdata, err := util.UnCompress(msg.Data) - if err != nil { - panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒") - } - i := protomsg.Image{} - err = proto.Unmarshal(bdata, &i) - //resp, err = util.PostFormBufferData(weedfsUrl, i, uuid.NewV4().String()) - resp, err = util.DrawPolygonOnImage(msg.Cid, i,msg.RuleResult["yolo"].([]ruleserver.Result)) - if err != nil { - logger.Error("鐢绘鎴栦笂浼犲浘鐗囨湇鍔″櫒鍑洪敊", err) - } else { - logger.Info("涓婁紶鐨勫浘鐗囦俊鎭細",resp) - } - } else { - isAlarm = 0 - // 涓嶆槸鎶ヨ鏁版嵁涓嶅瓨 - return - } - // logger.Println("鍥剧墖涓婁紶杩斿洖鍊硷細", resp) - // 鏌ヨ鏈満淇℃伅 + i := protomsg.Image{} + err = proto.Unmarshal(bdata, &i) + bigPhotoUrl := make(map[string]interface{}) + bigPhotoUrl, err = util.PostFormBufferData(weedfsUrl, i, uuid.NewV4().String()) + logger.Debug("========澶у浘璺緞锛�", bigPhotoUrl) + // 浜鸿劯妫�娴嬶紝娌℃湁鐩镐技鐨勫簳搴撲汉鍛� localConfig, err := cache.GetServerInfo() if err != nil { logger.Error("鏌ヨ鏈満淇℃伅澶辫触锛�") } + serverIp, err := GetLocalIP() // 鏌ヨcameraName camera, err := cache.GetCameraById(msg.Cid) if err != nil { logger.Error("鏌ヨ鎽勫儚鏈轰俊鎭け璐�") } - serverIp, err := GetLocalIP() - peraction := Personaction{ + bytes := util.SubImg(i, int(face.Location.X), int(face.Location.Y), int(face.Location.X+face.Location.Width), int(face.Location.Y+face.Location.Height)) + resp, err := util.PostFormBufferData1(weedfsUrl, bytes, uuid.NewV4().String()) + if err != nil { + logger.Error("涓婁紶灏忓浘鍑洪敊") + } + logger.Info("================灏忓浘鍦板潃:", resp["fileUrl"].(string)) + sex := "" + if face.ThftRes.Gender == 1 { + sex = "鐢�" + } else { + sex = "濂�" + } + race := getRaceString(face.ThftRes.Race) + ageDescription := getDescription(face.ThftRes.Age) + + pervideo := PerVideoPicture{ uuid.NewV4().String(), msg.Cid, - camera.Name, camera.Addr, + time.Now().Format("2006-01-02 15:04:05"), + strings.Split(bigPhotoUrl["fileUrl"].(string), "/")[1], msg.Tasklab.Taskid, msg.Tasklab.Taskname, - sdkNames, + "浜鸿劯", "", - alarmRules, + time.Now().Format("2006-01-02 15:04:05"), // 鍙娴嬶紝娌℃湁姣斿鏃堕棿 + sex, + face.ThftRes.Age, + ageDescription, + race, + face.ThftRes.Smile, + face.ThftRes.Beauty, + string(face.Feature), + []string{strings.Split(resp["fileUrl"].(string), "/")[1]}, + "鏆傛棤闆嗙兢", localConfig.ServerId, localConfig.ServerName, serverIp, "", - []string{strings.Split(resp["fileUrl"].(string), "/")[1]}, - time.Now().Format("2006-01-02 15:04:05"), - "", - isAlarm, + face.Score, + 1, 0, 0, 0, + face.Liker, } - requstbody, err := json.Marshal(peraction) + requstbody, err := json.Marshal(pervideo) if err != nil { logger.Info("json parse error ", err) return - } - err = EsReq("POST", "http://192.168.1.182:9200/personaction/perVideoAction", requstbody) - if err != nil { - logger.Error("寰�ES鎻掑叆鏁版嵁澶辫触", err) - } else { - logger.Warn("__________________________________________寰�ES鎻掑叆yolo鏁版嵁鎴愬姛") - //os.Exit(1) + err1 := EsReq("POST", "http://192.168.1.182:9200/videopersons/perVideoPicture", requstbody) + if err1 != nil { + logger.Error("涓婁紶ES鍑洪敊锛�---", err1) } } } } +func ChangeStatusFace(msg ruleserver.ResultMsg) { + logger.Info("寰�ES鎻掗潪鎶ヨ浣嗘槸鐘舵�佽浆鎹㈡暟鎹�") + // 涓婁紶澶у浘 + // 瑙e帇缂╁苟涓婁紶鍥剧墖 + bdata, err := util.UnCompress(msg.Data) + if err != nil { + panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒") + } + i := protomsg.Image{} + err = proto.Unmarshal(bdata, &i) + bigPhotoUrl := make(map[string]interface{}) + bigPhotoUrl, err = util.PostFormBufferData(weedfsUrl, i, uuid.NewV4().String()) + logger.Debug("========澶у浘璺緞锛�", bigPhotoUrl) + // 浜鸿劯妫�娴嬶紝娌℃湁鐩镐技鐨勫簳搴撲汉鍛� + localConfig, err := cache.GetServerInfo() + if err != nil { + logger.Error("鏌ヨ鏈満淇℃伅澶辫触锛�") + } + serverIp, err := GetLocalIP() + // 鏌ヨcameraName + camera, err := cache.GetCameraById(msg.Cid) + if err != nil { + logger.Error("鏌ヨ鎽勫儚鏈轰俊鎭け璐�") + } + pervideo := PerVideoPicture{ + uuid.NewV4().String(), + msg.Cid, + camera.Addr, + time.Now().Format("2006-01-02 15:04:05"), + strings.Split(bigPhotoUrl["fileUrl"].(string), "/")[1], + msg.Tasklab.Taskid, + msg.Tasklab.Taskname, + "浜鸿劯", + "鐘舵�佽浆鎹㈡暟鎹紝闈炴姤璀︽暟鎹�", + time.Now().Format("2006-01-02 15:04:05"), // 鍙娴嬶紝娌℃湁姣斿鏃堕棿 + "", + 0, + "", + "", + 0, + 0, + "", + []string{""}, + "鏆傛棤闆嗙兢", + localConfig.ServerId, + localConfig.ServerName, + serverIp, + "", + 0, + 1, + 0, + 0, + 0, + []*protomsg.Baseinfo{}, + } + requstbody, err := json.Marshal(pervideo) + + if err != nil { + logger.Info("json parse error ", err) + return + } + err1 := EsReq("POST", "http://192.168.1.182:9200/videopersons/perVideoPicture", requstbody) + if err1 != nil { + logger.Error("涓婁紶ES鍑洪敊锛�---", err1) + } +} + +// 寰�es涓彃鍏olo鏁版嵁 +func InsertYolo(msg ruleserver.ResultMsg) { + if msg.RuleResult["yolo"] != nil && len(msg.RuleResult["yolo"].([]ruleserver.Result)) > 0 { + logger.Info("寰�ES鎻抷olo鏁版嵁") + var sdkNames string = "" + alarmRules := []AlarmRule{} + for _, yoloResult := range msg.RuleResult["yolo"].([]ruleserver.Result) { + sdkNames = sdkNames + yoloResult.SdkName + alarm := ChangeToString(yoloResult.AlarmLevel) + alarmRules = append(alarmRules, AlarmRule{yoloResult.RuleGroupId, alarm, yoloResult.RuleText}) + } + isAlarm := 0 + resp := make(map[string]interface{}) + if len(alarmRules) > 0 { + isAlarm = 1 + // 瑙e帇缂╁苟涓婁紶鍥剧墖 + bdata, err := util.UnCompress(msg.Data) + if err != nil { + panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒") + } + i := protomsg.Image{} + err = proto.Unmarshal(bdata, &i) + //resp, err = util.PostFormBufferData(weedfsUrl, i, uuid.NewV4().String()) + resp, err = util.DrawPolygonOnImage(msg.Cid, i, msg.RuleResult["yolo"].([]ruleserver.Result)) + if err != nil { + logger.Error("鐢绘鎴栦笂浼犲浘鐗囨湇鍔″櫒鍑洪敊", err) + } else { + logger.Info("涓婁紶鐨勫浘鐗囦俊鎭細", resp) + } + } else { + isAlarm = 0 + // 涓嶆槸鎶ヨ鏁版嵁涓嶅瓨 + return + } + // logger.Println("鍥剧墖涓婁紶杩斿洖鍊硷細", resp) + // 鏌ヨ鏈満淇℃伅 + localConfig, err := cache.GetServerInfo() + if err != nil { + logger.Error("鏌ヨ鏈満淇℃伅澶辫触锛�") + } + // 鏌ヨcameraName + camera, err := cache.GetCameraById(msg.Cid) + if err != nil { + logger.Error("鏌ヨ鎽勫儚鏈轰俊鎭け璐�") + } + serverIp, err := GetLocalIP() + peraction := Personaction{ + uuid.NewV4().String(), + msg.Cid, + camera.Name, + camera.Addr, + msg.Tasklab.Taskid, + msg.Tasklab.Taskname, + sdkNames, + "", + alarmRules, + localConfig.ServerId, + localConfig.ServerName, + serverIp, + "", + []string{strings.Split(resp["fileUrl"].(string), "/")[1]}, + time.Now().Format("2006-01-02 15:04:05"), + "", + isAlarm, + 0, + 0, + 0, + } + requstbody, err := json.Marshal(peraction) + + if err != nil { + logger.Info("json parse error ", err) + return + + } + err = EsReq("POST", "http://192.168.1.182:9200/personaction/perVideoAction", requstbody) + if err != nil { + logger.Error("寰�ES鎻掑叆鏁版嵁澶辫触", err) + } else { + logger.Warn("__________________________________________寰�ES鎻掑叆yolo鏁版嵁鎴愬姛") + //os.Exit(1) + } + } +} +func ChangeStatusYolo(msg ruleserver.ResultMsg) { + logger.Info("寰�ES鎻抷olo闈炴姤璀︾姸鎬佹敼鍙樻暟鎹�") + var sdkNames string = "" + alarmRules := []AlarmRule{} + bdata, err := util.UnCompress(msg.Data) + if err != nil { + panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒") + } + i := protomsg.Image{} + err = proto.Unmarshal(bdata, &i) + //resp, err = util.PostFormBufferData(weedfsUrl, i, uuid.NewV4().String()) + resp, err := util.DrawPolygonOnImage(msg.Cid, i, msg.RuleResult["yolo"].([]ruleserver.Result)) + if err != nil { + logger.Error("鐢绘鎴栦笂浼犲浘鐗囨湇鍔″櫒鍑洪敊", err) + } else { + logger.Info("涓婁紶鐨勫浘鐗囦俊鎭細", resp) + } + // logger.Println("鍥剧墖涓婁紶杩斿洖鍊硷細", resp) + // 鏌ヨ鏈満淇℃伅 + localConfig, err := cache.GetServerInfo() + if err != nil { + logger.Error("鏌ヨ鏈満淇℃伅澶辫触锛�") + } + // 鏌ヨcameraName + camera, err := cache.GetCameraById(msg.Cid) + if err != nil { + logger.Error("鏌ヨ鎽勫儚鏈轰俊鎭け璐�") + } + serverIp, err := GetLocalIP() + peraction := Personaction{ + uuid.NewV4().String(), + msg.Cid, + camera.Name, + camera.Addr, + msg.Tasklab.Taskid, + msg.Tasklab.Taskname, + sdkNames, + "yolo闈炴姤璀︾姸鎬佹敼鍙樻暟鎹�", + alarmRules, + localConfig.ServerId, + localConfig.ServerName, + serverIp, + "", + []string{strings.Split(resp["fileUrl"].(string), "/")[1]}, + time.Now().Format("2006-01-02 15:04:05"), + "", + 0, + 0, + 0, + 0, + } + requstbody, err := json.Marshal(peraction) + + if err != nil { + logger.Info("json parse error ", err) + return + + } + err = EsReq("POST", "http://192.168.1.182:9200/personaction/perVideoAction", requstbody) + if err != nil { + logger.Error("寰�ES鎻掑叆鏁版嵁澶辫触", err) + } else { + logger.Warn("__________________________________________寰�ES鎻掑叆yolo鏁版嵁鎴愬姛") + //os.Exit(1) + } +} // 鑾峰彇鏈満ip func GetLocalIP() (ipv4 string, err error) { var ( diff --git a/main.go b/main.go index 6154d6d..43b93b7 100644 --- a/main.go +++ b/main.go @@ -69,9 +69,9 @@ arg := ruleserver.SdkDatas{} m := paramFormat(msg, &arg) //logger.Info("瑙f瀽鍑烘潵鐨勬暟鎹細", arg) - ruleserver.Judge(&arg) + ruleserver.Judge(&arg,&m) // 鎶妔dkMessage浼犺繘鍘伙紝鏂逛究缂撳瓨鏁版嵁鏃舵嫾鍑轰竴涓猺esultMag // 鎶奱rg閲岀殑鎵撶殑鏍囩鎷垮嚭鏉ョ粰m鍐嶅皝瑁呬竴灞� - resultMag := ruleserver.ResultMsg{SdkMessage: m, RuleResult: arg.RuleResult} + resultMag := ruleserver.ResultMsg{SdkMessage: &m, RuleResult: arg.RuleResult} //logger.Info("鎵撳畬鏍囩鍚庣殑缁撴灉锛�",resultMag) // 灏嗘墦瀹屾爣绛剧殑鏁版嵁鎻掑叆鍒癊S diff --git a/ruleserver/ruleToformula.go b/ruleserver/ruleToformula.go index 938f6a1..74719eb 100644 --- a/ruleserver/ruleToformula.go +++ b/ruleserver/ruleToformula.go @@ -129,7 +129,7 @@ //protomsg.SdkMessage.TaskLabel.SdkmsgWithTask.sdkdata type ResultMsg struct { - protomsg.SdkMessage + *protomsg.SdkMessage RuleResult map[string]interface{} // 杩囧畬瑙勫垯鍚庢墦鐨勬爣绛� } @@ -186,7 +186,7 @@ } // 瀵瑰崟甯у浘鍍忕殑鍒ゆ柇 thisSdkDatas 褰撳墠浼犲叆鐨勮繖甯ф暟鎹紝cacheSdkData 瀹氭椂鍣ㄩ噷缂撳瓨鐨勪竴甯ф暟鎹� 娌℃湁灏辫繑鍥瀗il (thisSdkDatas SdkDatas, cacheSdkDatas SdkDatas) -func Judge(args *SdkDatas) { +func Judge(args *SdkDatas,message *protomsg.SdkMessage) { if len(args.Sdkdata) > 0 { // 鎷垮埌鏈憚鍍忔満鐨勫尯鍩� cameraPolygons := GetPolygons(args.CameraId) @@ -212,10 +212,10 @@ if len(temp) > 0 { if ruleList[i].SetType == "linkTask" { // groupId涓惈鏈塴ink鍒欎负鑱斿姩浠诲姟 - LinkTask(args, ruleList[i], taskId) + LinkTask(args, ruleList[i], taskId,message) } else { // 鐙珛浠诲姟鐨勫鐞� - RunRule(args, ruleList[i], taskId) + RunRule(args, ruleList[i], taskId,message) } } } @@ -306,7 +306,7 @@ } } } -func RunRule(args *SdkDatas, groupRule *protomsg.GroupRule, taskId string) bool { +func RunRule(args *SdkDatas, groupRule *protomsg.GroupRule, taskId string,message *protomsg.SdkMessage) bool { defer func() { if err := recover(); err != nil { logger.Error("姣斿瑙勫垯鏈夎", err.(string)) @@ -417,7 +417,7 @@ if ipcId == sdkData.IpcId { for _, areaMap := range sdkData.AreaMapList { // 鍘诲紑鍚竴涓畾鏃跺櫒 - duration(groupRule.Rules[j], groupRule.GroupId, areaMap, args) + duration(groupRule.Rules[j], groupRule.GroupId, areaMap, args,message) } } } @@ -533,10 +533,14 @@ } else { // 缁撴灉涓哄亣 for k, timeEle := range TimeEleList { if strings.Contains(k, groupId) { - logger.Debug("------------------------------閲嶇疆瀹氭椂鍣紝姝ゆ椂鐨勮鏁板櫒鐨勫�间负",timeEle.N) - timeEle.N = timeEle.InitN // 閲嶇疆瀹氭椂鍣� - timeEle.CacheSdkData = SdkDatas{} // 鎶婄紦瀛樻暟鎹墧浜� - flagTime = "12" + if timeEle.AlarmFlag { + logger.Debug("------------------------------鏉�姝诲畾鏃跺櫒锛屾姤璀︽甯х姸鎬佹敼鍙樼殑鏁版嵁锛屾鏃剁殑璁℃暟鍣ㄧ殑鍊间负",timeEle.N) + flagTime = "12" + args.RuleResult["timeLabel"] = flagTime + delete(TimeEleList,k) + } else { + delete(TimeEleList,k) + } } } @@ -544,6 +548,7 @@ } else { // 鏃犲畾鏃跺櫒 if result { flagTime = "01" + args.RuleResult["timeLabel"] = flagTime } else { flagTime = "00" } @@ -628,7 +633,7 @@ } // 鑱斿姩浠诲姟鐨勫鐞� -func LinkTask(args *SdkDatas, groupRule *protomsg.GroupRule, taskId string) { +func LinkTask(args *SdkDatas, groupRule *protomsg.GroupRule, taskId string,message *protomsg.SdkMessage) { // new涓�涓畾鏃跺櫒锛屽鏋滀互姝roupId涓烘爣蹇楃殑瀹氭椂鍣ㄤ笉瀛樺湪鐨勮瘽 logger.Info("------------------------------------------褰撳墠鏄仈鍔ㄤ换鍔★紝瑙勫垯鏄細", groupRule.GroupText) var flag bool = true @@ -658,7 +663,7 @@ } } // 寰�鏁扮粍閲岃祴鍊� - isOk := RunRule(args, groupRule, taskId) + isOk := RunRule(args, groupRule, taskId,message) if isOk { logger.Info("杩欏抚鍥惧儚鍦ㄤ换鍔′笅鐨勪竴鏁存潯瑙勫垯涓嬶紙鑱斿姩浠诲姟涓嬪氨鏄窡鏈憚鍍忔満鍍忕浉鍏崇殑灏忚鍒欙級鐨勫垽鏂粨鏋滀负true") // 鏍规嵁cameraId鍘绘洿鏂版垨鑰呮彃鍏ョ粨鏋�,鐒跺悗鍒ゆ柇鏄惁鏁扮粍鏄惁鍙互寰楀嚭鎶ヨ鐨勭粨璁� @@ -854,7 +859,7 @@ } // 濡傛灉鏈夋寔缁椂闂存潯浠剁淮鎶ゅ紑鍚竴涓畾鏃跺櫒 -func duration(rule *protomsg.Rule, groupId string, am *AreaMap, args *SdkDatas) { +func duration(rule *protomsg.Rule, groupId string, am *AreaMap, args *SdkDatas,message *protomsg.SdkMessage) { if rule.PolygonId == am.areaId { // 棣栧厛瑙勫垯鎵�瀵瑰簲鐨勫尯鍩焛d瑕佽窡鍖哄煙鏁版嵁鐨刬d瀵圭殑涓� 閰嶇疆鐨勭畻娉曡瀵圭殑涓� if rule.SdkArgAlias == "duration" { // // 鍏堢湅鐪嬪畾鏃跺櫒鍏冪礌闃熷垪涓槸鍚︽湁杩欎釜鎽勫儚鏈鸿繖涓尯鍩熺殑瀹氭椂鍣�,濡傛灉鏈夊氨涓嶈兘鍐嶆鍒涘缓浜� @@ -868,7 +873,7 @@ if flag { timeLength, _ := strconv.Atoi(rule.SdkArgValue) - timeEle := TimeElement{N: timeLength, InitN: timeLength, AlarmFlag: false, CacheSdkData: *args} // 鎵旇繘鍘讳竴涓畾鏃跺櫒鍏冪礌锛堝苟缂撳瓨褰撳墠鐢婚潰甯ф暟鎹級 + timeEle := TimeElement{N: timeLength, InitN: timeLength, AlarmFlag: false, CacheSdkData: &ResultMsg{message,args.RuleResult}} // 鎵旇繘鍘讳竴涓畾鏃跺櫒鍏冪礌锛堝苟缂撳瓨褰撳墠鐢婚潰甯ф暟鎹級 //TimeEleList = make(map[string]timeElement) TimeEleList[groupId+" "+rule.Id] = &timeEle // 瀹氭椂鍣ㄥ厓绱犱互鎽勫儚鏈篿d鎷兼帴鍖哄煙id涓洪敭 logger.Info("鍒涘缓浜嗚鏁板櫒骞朵笖璁℃暟鍣ㄩ泦鍚堜负锛�", TimeEleList) diff --git a/ruleserver/timeTicker.go b/ruleserver/timeTicker.go index 12e4818..7e2cecf 100644 --- a/ruleserver/timeTicker.go +++ b/ruleserver/timeTicker.go @@ -13,12 +13,12 @@ // 瀹氭椂鍣ㄥ厓绱� type TimeElement struct { - N int // 鎸夋椂闂翠緷娆¢�掑噺鐨勫綋鍓嶅�� - InitN int // 璧嬪�煎悗灏变笉鍙樼殑鍒濆鍊� - BufferFlag int // 缂撳啿瀹归敊浣� 杩炵画甯alse鎵嶄负false - AlarmFlag bool // 鎶ヨ鏍囧織浣� 瀹氭椂鍣ㄥ紑鍚悗绗竴娆℃姤璀︽椂浼氳缃负true 寰�鍚庡啀鏉ユ姤璀︿篃涓嶄細鎻掕繘ES - CacheSdkData SdkDatas // 瀹氭椂鍣ㄧ殑缂撳瓨鏁版嵁 鎸佺画鏃堕棿绫荤殑寮�鍚畾鏃跺櫒鏃惰缂撳瓨涓�甯� - GroupId string // 鑱斿姩瑙勫垯闇�瑕佽褰曚笅姝ゆ椂鐨勮鍒欑粍id + N int // 鎸夋椂闂翠緷娆¢�掑噺鐨勫綋鍓嶅�� + InitN int // 璧嬪�煎悗灏变笉鍙樼殑鍒濆鍊� + BufferFlag int // 缂撳啿瀹归敊浣� 杩炵画甯alse鎵嶄负false + AlarmFlag bool // 鎶ヨ鏍囧織浣� 瀹氭椂鍣ㄥ紑鍚悗绗竴娆℃姤璀︽椂浼氳缃负true 寰�鍚庡啀鏉ユ姤璀︿篃涓嶄細鎻掕繘ES + CacheSdkData *ResultMsg // 瀹氭椂鍣ㄧ殑缂撳瓨鏁版嵁 鎸佺画鏃堕棿绫荤殑寮�鍚畾鏃跺櫒鏃惰缂撳瓨涓�甯� + GroupId string // 鑱斿姩瑙勫垯闇�瑕佽褰曚笅姝ゆ椂鐨勮鍒欑粍id RuleResults []*RuleResult } type RuleResult struct { @@ -46,9 +46,9 @@ timeEle.N = timeEle.N - 1 logger.Error("-------------------------------------鎵撳嵃瀹氭椂鍣ㄥ厓绱犲綋鍓嶅��-----------------------------------------锛�", timeEle.N) } - if timeEle.GroupId != "" && timeEle.N == 0{ + if timeEle.GroupId != "" && timeEle.N == 0 { // 璇存槑鏄仈鍔ㄤ换鍔$殑鏃堕棿绐楀彛 鍒扮偣鍎夸簡璇ラ攢姣佷簡,鍐嶆潵浜嗗啀鍒涘缓 - delete(TimeEleList,k) + delete(TimeEleList, k) } } case stop := <-stopChan: @@ -65,7 +65,6 @@ stopChan <- true TimeTicker() } - // 缁撴瀯浣撴牴鎹煇瀛楁鎺掑簭 type SubList []*RuleResult -- Gitblit v1.8.0