From b04d36589f44e3dbc163a0a2a64fc765773d8c64 Mon Sep 17 00:00:00 2001 From: liuxiaolong <736321739@qq.com> Date: 星期二, 02 七月 2019 11:45:29 +0800 Subject: [PATCH] add camera and localconfig cache --- cache/cache.go | 39 +++++++++++++++++++++++++++++++++++++++ 1 files changed, 39 insertions(+), 0 deletions(-) diff --git a/cache/cache.go b/cache/cache.go index f72a1e0..70af5aa 100644 --- a/cache/cache.go +++ b/cache/cache.go @@ -11,9 +11,11 @@ "strconv" ) const ( + PREFIX_CAMERA = "CAMERA_" PREFIX_POLYGON = "POLYGON_" PREFIX_TIME = "TIME_" PREFIX_RULE = "RULE_" + SERVER_KEY = "SERVERINFO" ) var cMap *shardmap.ShardMap @@ -44,6 +46,10 @@ initCameraTaskRules()//鍒濆鍖栨憚鍍忔満浠诲姟瑙勫垯缂撳瓨 + initCamera()//鍒濆鍖栨憚鍍忔満淇℃伅 + + initServerInfo()//鍒濆鍖栨湇鍔″櫒閰嶇疆淇℃伅 + initChan <- true } @@ -64,6 +70,22 @@ 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) } } @@ -104,7 +126,24 @@ } } +func GetServerInfo() *protomsg.LocalConfig { + config, b := cMap.Get(SERVER_KEY) + if b { + return config.(*protomsg.LocalConfig) + } else { + return nil + } +} +//閫氳繃cameraId鑾峰彇鎽勫儚鏈轰俊鎭� +func GetCameraById(cameraId string) *protomsg.Camera { + cam, b := cMap.Get(PREFIX_CAMERA + cameraId) + if b { + return cam.(*protomsg.Camera) + } else { + return nil + } +} func GetPolygonsByCameraId(cameraId string) []protomsg.CameraPolygon{ obj, b := cMap.Get(PREFIX_POLYGON + cameraId) -- Gitblit v1.8.0