package main import ( "context" "flag" "os" "os/signal" "syscall" "vamicro/config" "vamicro/search-service/controllers" "basic.com/valib/bhomeclient.git" "basic.com/valib/bhomedbapi.git" "basic.com/valib/logger.git" vaversion "basic.com/valib/version.git" ) var ( procName = "search-service" proc = &bhomeclient.ProcInfo{ Name: procName, //进程名称 ID: procName, //进程id Info: "", //进程的描述信息,用于区分同一进程名称下多个进程 } env = flag.String("e", "pro", "") ) func init() { flag.Parse() vaversion.Usage() config.Init(*env) // 日志初始化 var logFile = config.LogConf.Path + "vamicro-" + procName + ".log" logger.InitLogger(logFile, config.LogConf.Level, config.LogConf.MaxSize, config.LogConf.MaxBackups, config.LogConf.MaxAge) logger.Info("log init success !") } func main() { ctx, cancel := context.WithCancel(context.Background()) fm, pubTopics := initFuncMap() var reg = &bhomeclient.RegisterInfo{ Proc: *proc, Channel: nil, PubTopic: pubTopics, SubTopic: []string{}, } q := make(chan os.Signal, 1) signal.Notify(q, os.Interrupt, os.Kill, syscall.SIGTERM) ms, err := bhomeclient.NewMicroNode(ctx, q, config.Server.AnalyServerId, reg, logger.Debug) if err != nil { return } bhomedbapi.InitLog(logger.Debug) bhomedbapi.InitGetNetNode(ms.GetLocalNetNodeByTopic) bhomedbapi.InitDoReq(ms.RequestOnly) go ms.StartServer(fm) <-q ms.DeRegister() cancel() ms.Free() } const urlPrefix = "/data/api-v" func initFuncMap() (map[string]bhomeclient.MicroFunc, []string) { funcMap := make(map[string]bhomeclient.MicroFunc) sc := new(controllers.EsSearchController) // tc := new(controllers.TaskController) funcMap[urlPrefix+"/dbperson/faceExtract"] = sc.FaceExtract funcMap[urlPrefix+"/dbperson/searchByPhoto"] = sc.SearchByPhoto funcMap[urlPrefix+"/es/queryEsCompareData"] = sc.PostEsCompareData funcMap[urlPrefix+"/es/esSearch"] = sc.PostEsSearch funcMap[urlPrefix+"/es/tagList"] = sc.PostEsTagList funcMap[urlPrefix+"/es/taskList"] = sc.PostEsTaskList // funcMap[urlPrefix+"/task/aggregateTaskList"] = tc.AggregateTaskList funcMap[urlPrefix+"/es/collect"] = sc.Collect funcMap[urlPrefix+"/es/deleteById"] = sc.PostEsDelete funcMap[urlPrefix+"/es/signMisreport"] = sc.SignMisreport funcMap[urlPrefix+"/es/esSearchAggs"] = sc.PostEsSearchAggs // 对应接口文档 funcMap[urlPrefix+"/rdb/tagList"] = sc.PostEsTagList funcMap[urlPrefix+"/rdb/taskList"] = sc.PostEsTaskList funcMap[urlPrefix+"/rdb/search"] = sc.PostEsSearch funcMap[urlPrefix+"/rdb/queryCompareData"] = sc.PostEsCompareData funcMap[urlPrefix+"/rdb/analysis/history/video"] = sc.GetVideoUrl var pubTopics []string for key, _ := range funcMap { pubTopics = append(pubTopics, key) } return funcMap, pubTopics }