From 0b1342328dfded3e86396f2866cad01a66a1113d Mon Sep 17 00:00:00 2001 From: Congqi Xia Date: Wed, 11 Dec 2024 17:11:48 +0800 Subject: [PATCH] fix: Check target partition load state only when dropping partition Related to #38372 This PR make drop partition only check target partition load states only in case of concurrent releasing other partition in same collection. Signed-off-by: Congqi Xia --- internal/proxy/util.go | 17 ++++------------- 1 file changed, 4 insertions(+), 13 deletions(-) diff --git a/internal/proxy/util.go b/internal/proxy/util.go index 15f4f3649096b..708641dec9d95 100644 --- a/internal/proxy/util.go +++ b/internal/proxy/util.go @@ -49,6 +49,7 @@ import ( "github.com/milvus-io/milvus/pkg/util/commonpbutil" "github.com/milvus-io/milvus/pkg/util/contextutil" "github.com/milvus-io/milvus/pkg/util/crypto" + "github.com/milvus-io/milvus/pkg/util/funcutil" "github.com/milvus-io/milvus/pkg/util/merr" "github.com/milvus-io/milvus/pkg/util/metric" "github.com/milvus-io/milvus/pkg/util/paramtable" @@ -1410,23 +1411,13 @@ func isPartitionLoaded(ctx context.Context, qc types.QueryCoordClient, collID in // get all loading collections resp, err := qc.ShowPartitions(ctx, &querypb.ShowPartitionsRequest{ CollectionID: collID, - PartitionIDs: nil, + PartitionIDs: partIDs, }) - if err != nil { + if err := merr.CheckRPCCall(resp, err); err != nil { return false, err } - if resp.GetStatus().GetErrorCode() != commonpb.ErrorCode_Success { - return false, merr.Error(resp.GetStatus()) - } - for _, loadedPartID := range resp.GetPartitionIDs() { - for _, partID := range partIDs { - if partID == loadedPartID { - return true, nil - } - } - } - return false, nil + return funcutil.SliceSetEqual(partIDs, resp.GetPartitionIDs()), nil } func checkFieldsDataBySchema(schema *schemapb.CollectionSchema, insertMsg *msgstream.InsertMsg, inInsert bool) error {