From dcd904d2fa347b00e9e19634274d8c418b67b1e4 Mon Sep 17 00:00:00 2001 From: "zhenshan.cao" Date: Mon, 16 Sep 2024 11:01:25 +0800 Subject: [PATCH] fix: keep inner topK to avoid exceeding efSearch (#36284) issue: #https://github.com/milvus-io/milvus/issues/36243 Signed-off-by: zhenshan.cao --- internal/proxy/search_util.go | 6 +----- internal/proxy/task_search_test.go | 6 +++--- 2 files changed, 4 insertions(+), 8 deletions(-) diff --git a/internal/proxy/search_util.go b/internal/proxy/search_util.go index f1cb82b93800d..55fee866936a6 100644 --- a/internal/proxy/search_util.go +++ b/internal/proxy/search_util.go @@ -70,11 +70,7 @@ func parseSearchInfo(searchParamsPair []*commonpb.KeyValuePair, schema *schemapb } topK = externalLimit } else { - if topKInParam < externalLimit { - topK = externalLimit - } else { - topK = topKInParam - } + topK = topKInParam } } diff --git a/internal/proxy/task_search_test.go b/internal/proxy/task_search_test.go index 80cfaeae26613..216ada26776bb 100644 --- a/internal/proxy/task_search_test.go +++ b/internal/proxy/task_search_test.go @@ -2259,7 +2259,7 @@ func TestTaskSearch_parseSearchInfo(t *testing.T) { info, offset, err := parseSearchInfo(offsetParam, nil, rank) assert.NoError(t, err) assert.NotNil(t, info) - assert.Equal(t, externalLimit, info.GetTopk()) + assert.Equal(t, int64(10), info.GetTopk()) assert.Equal(t, int64(0), offset) }) @@ -2446,13 +2446,13 @@ func TestTaskSearch_parseSearchInfo(t *testing.T) { schema := &schemapb.CollectionSchema{ Fields: fields, } - info, _, err := parseSearchInfo(normalParam, schema, false) + info, _, err := parseSearchInfo(normalParam, schema, nil) assert.Nil(t, info) assert.Error(t, err) assert.True(t, strings.Contains(err.Error(), "exceeds configured max group size")) resetSearchParamsValue(normalParam, GroupSizeKey, `10`) - info, _, err = parseSearchInfo(normalParam, schema, false) + info, _, err = parseSearchInfo(normalParam, schema, nil) assert.NotNil(t, info) assert.NoError(t, err) })