From 123a0b3e2e632f0a200234e6b2ed47bc5aafe5eb Mon Sep 17 00:00:00 2001 From: simon Date: Mon, 6 May 2024 12:11:12 +0800 Subject: [PATCH] knowledge api timeout --- prerank-stages/api/knowledge.go | 17 ++++++++--------- prerank-stages/prerank/main.go | 6 +++++- 2 files changed, 13 insertions(+), 10 deletions(-) diff --git a/prerank-stages/api/knowledge.go b/prerank-stages/api/knowledge.go index 59aa4da..0d639ec 100644 --- a/prerank-stages/api/knowledge.go +++ b/prerank-stages/api/knowledge.go @@ -15,31 +15,30 @@ import ( "go.uber.org/zap" ) -func LoadEntriesInMongo() map[string]int { +func LoadEntriesInMongo() (map[string]int, error) { existEntryList := make(map[string]int, 0) url := common.EntryAlgorithmMonogoApiUrl() + common.GetAlgorithmSource() - client := &http.Client{Timeout: time.Second * 5} + client := &http.Client{Timeout: time.Second * 30} res, err := client.Get(url) if err != nil { common.Logger.Error("get entry data fail", zap.Error(err)) - return existEntryList + return existEntryList, err } if res.StatusCode != 200 { common.Logger.Error("get entry data fail code") - return existEntryList } defer res.Body.Close() body, _ := io.ReadAll(res.Body) var resObj model.KnowledgeApiResponseModel if err := json.Unmarshal(body, &resObj); err != nil { - log.Print("json decode failed, err", err) - return existEntryList + common.Logger.Error("json decode failed, err", zap.Error(err)) + return existEntryList, err } for _, jsonObj := range resObj.Data { existEntryList[jsonObj] = 1 } - return existEntryList + return existEntryList, nil } @@ -54,7 +53,7 @@ func AddEntriesInMongo(list []*model.EntryModel) { url := common.EntryMonogoEntryApiUrl() request, _ := http.NewRequest("POST", url, bytes.NewBuffer(jsonByte)) request.Header.Set("Content-Type", "application/json") - client := &http.Client{Timeout: time.Second * 5} + client := &http.Client{Timeout: time.Second * 10} response, err := client.Do(request) if err != nil { common.Logger.Error("add entry in mongo fail", zap.Error(err)) @@ -120,7 +119,7 @@ func DelEntriesInMongo(list []string) { url := common.EntryMonogoEntryApiUrl() + common.GetAlgorithmSource() request, _ := http.NewRequest("DELETE", url, bytes.NewBuffer(jsonByte)) request.Header.Set("Content-Type", "application/json") - client := &http.Client{Timeout: time.Second * 5} + client := &http.Client{Timeout: time.Second * 30} _, err := client.Do(request) defer request.Body.Close() diff --git a/prerank-stages/prerank/main.go b/prerank-stages/prerank/main.go index 86fc151..43b3a27 100644 --- a/prerank-stages/prerank/main.go +++ b/prerank-stages/prerank/main.go @@ -78,7 +78,11 @@ func entryPrerankCal(language string, maxNum int, startTimestamp int64, userEmbe func entriesSaveToMongo(currentList []*model.EntryModel) { - existEntriesMap := api.LoadEntriesInMongo() + existEntriesMap, loadError := api.LoadEntriesInMongo() + if loadError != nil { + common.Logger.Info("add entry to mongo error,failed save") + return + } common.Logger.Info("load entry in mongo..", zap.Int("len", len(existEntriesMap))) common.Logger.Info("prerank save ..", zap.Int("len", len(currentList))) addCnt := 1