From e6982607fbbeaa96d3d14409df780266646b793d Mon Sep 17 00:00:00 2001 From: panlei <2799247126@qq.com> Date: 星期五, 01 十一月 2019 18:22:44 +0800 Subject: [PATCH] 换一个chan --- cache/cache.go | 204 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 204 insertions(+), 0 deletions(-) diff --git a/cache/cache.go b/cache/cache.go index 08bf029..a50f676 100644 --- a/cache/cache.go +++ b/cache/cache.go @@ -1 +1,205 @@ package cache + +import ( + "basic.com/dbapi.git" + "basic.com/pubsub/cache.git/shardmap" + "basic.com/pubsub/protomsg.git" + "basic.com/valib/gopherdiscovery.git" + "errors" + "fmt" + "github.com/gogo/protobuf/proto" + "github.com/satori/go.uuid" + "strconv" +) +const ( + PREFIX_CAMERA = "CAMERA_" + PREFIX_POLYGON = "POLYGON_" + PREFIX_TIME = "TIME_" + PREFIX_RULE = "RULE_" + SERVER_KEY = "SERVERINFO" + PREFIX_SDK = "SDK_" +) + +var cMap *shardmap.ShardMap + + +func Init(initChan chan bool,dbIp string,surveyPort int,pubSubPort int){ + cMap = shardmap.New(uint8(32)) + urlSurvey := "tcp://" + dbIp + ":" + strconv.Itoa(surveyPort) + urlPubSub := "tcp://" + dbIp + ":" + strconv.Itoa(pubSubPort) + client, _ := gopherdiscovery.ClientWithSub(urlSurvey, urlPubSub, uuid.NewV4().String()) + recvMsg := client.HeartBeatMsg() + fmt.Println(<-recvMsg) + + initCacheData(initChan) + + peers, _ := client.Peers() + for b := range peers{ + fmt.Println("peerMsg:",b) + updateData(b) + } +} + +func initCacheData(initChan chan bool) { + + initPolygons()//鍒濆鍖栨憚鍍忔満澶氳竟褰㈢紦瀛� + + initTimeRules()//鍒濆鍖栨椂闂磋鍒欑紦瀛� + + initCameraTaskRules()//鍒濆鍖栨憚鍍忔満浠诲姟瑙勫垯缂撳瓨 + + initCamera()//鍒濆鍖栨憚鍍忔満淇℃伅 + + initServerInfo()//鍒濆鍖栨湇鍔″櫒閰嶇疆淇℃伅 + + initSdks() //鍒濆鍖杝dk鍒楄〃淇℃伅 + + initChan <- true +} + +var newUpdateMsg = &protomsg.DbChangeMessage{} + +func updateData(b []byte){ + if err :=proto.Unmarshal(b,newUpdateMsg);err !=nil{ + fmt.Println("dbChangeMsg unmarshal err:",err) + return + } + switch newUpdateMsg.Table { + case protomsg.TableChanged_T_Server: + initServerInfo() + case protomsg.TableChanged_T_Camera: + initCamera() + case protomsg.TableChanged_T_CameraPolygon://鏇存柊鎽勫儚鏈哄鍙樺舰 + initPolygons() + case protomsg.TableChanged_T_TimeRule://鏇存柊鏃堕棿瑙勫垯 + initTimeRules() + case protomsg.TableChanged_T_CameraTask://鏇存柊鎽勫儚鏈鸿鍒欓厤缃弬鏁� + initCameraTaskRules() + case protomsg.TableChanged_T_CameraTaskArgs://鏇存柊鎽勫儚鏈鸿鍒欓厤缃弬鏁� + initCameraTaskRules() + case protomsg.TableChanged_T_Sdk://鏇存柊sdk閰嶇疆 + initSdks() + default: + fmt.Println("unknown operation") + + } +} + +func initServerInfo() { + var api dbapi.SysSetApi + b, s := api.GetServerInfo() + if b{ + cMap.Set(SERVER_KEY,s) + } +} + +func initCamera() { + var api dbapi.CameraApi + cameras := api.FindAll() + for _,cam := range cameras { + cMap.Set(PREFIX_CAMERA + cam.Id,cam) + } +} + +func initPolygons(){ + var api dbapi.CameraApi + data := api.FindAllPolygons() + pMap :=make(map[string][]protomsg.CameraPolygon,0) + for _, item := range data { + if item.Type != "line" { + cameraId :=item.CameraId + if _,ok :=pMap[cameraId];ok{ + pMap[cameraId] = append(pMap[cameraId],item) + } else{ + pMap[cameraId]=[]protomsg.CameraPolygon{item} + } + } + } + for k,v :=range pMap{ + cMap.Set(PREFIX_POLYGON + k,v) + } +} + +func initTimeRules(){ + var api dbapi.CameraApi + flag, rules := api.FindAllTimeRules() + if flag { + for _, rule := range rules { + cMap.Set(PREFIX_TIME+rule.Id, rule) + } + } +} + +func initCameraTaskRules(){ + var api dbapi.CameraTaskArgsApi + all := api.FindAll() + + for _, taskArg := range all { + cMap.Set(PREFIX_RULE+taskArg.CameraId,taskArg.TaskArgs) + } +} + +func initSdks(){ + var api dbapi.SdkApi + sdks := api.FindAll("") + for _,sdk :=range sdks { + cMap.Set(PREFIX_SDK+sdk.Id,sdk) + } +} + +func GetServerInfo() (con protomsg.LocalConfig,err error) { + config, b := cMap.Get(SERVER_KEY) + if b { + return config.(protomsg.LocalConfig),nil + } else { + return con,errors.New("conf not found") + } +} + +//閫氳繃cameraId鑾峰彇鎽勫儚鏈轰俊鎭� +func GetCameraById(cameraId string) (c protomsg.Camera,err error) { + cam, b := cMap.Get(PREFIX_CAMERA + cameraId) + if b { + return cam.(protomsg.Camera),nil + } else { + return c,errors.New("camera not found") + } +} + +func GetPolygonsByCameraId(cameraId string) []protomsg.CameraPolygon{ + obj, b := cMap.Get(PREFIX_POLYGON + cameraId) + if b { + return obj.([]protomsg.CameraPolygon) + } else { + return nil + } +} + +//浠庣紦瀛樹腑鑾峰彇鏃堕棿瑙勫垯 +func GetTimeRuleById(id string) (exist bool,rule protomsg.CameraTimerule){ + obj, b := cMap.Get(PREFIX_TIME + id) + if b { + return true,obj.(protomsg.CameraTimerule) + } else { + return false,rule + } +} + +//鏍规嵁鎽勫儚鏈篿d浠庣紦瀛樹腑鑾峰彇鎽勫儚鏈虹殑浠诲姟瑙勫垯璁剧疆 +func GetCameraTaskRulesByCameraId(cameraId string) []*protomsg.TaskGroupArgs { + obj, b := cMap.Get(PREFIX_RULE + cameraId) + if b { + return obj.([]*protomsg.TaskGroupArgs) + } else { + return nil + } +} + +func GetSdkById(sdkId string) (sdk protomsg.Sdk,err error){ + obj,b :=cMap.Get(PREFIX_SDK + sdkId) + if b { + return obj.(protomsg.Sdk),nil + } else { + return sdk,errors.New("sdk not found") + } +} \ No newline at end of file -- Gitblit v1.8.0