enhance: Add AllPartitionsID const to replace InvalidPartitionID (#31438)

"-1" as `InvalidPartitionID` previously used as All partition place
holder in delete cases. It's confusing and hard to maintain when a const
var has more than one meaning.

This PR add `AllPartitionsID` to replace these usages in delete
scenarios.

---------

Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>
pull/31456/head
congqixia 2024-03-20 19:01:05 +08:00 committed by GitHub
parent 88213030a0
commit a647b84f3e
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
12 changed files with 16 additions and 13 deletions

View File

@ -131,7 +131,7 @@ func (h *ServerHandler) GetQueryVChanPositions(channel RWChannel, partitionIDs .
validPartitions := lo.Filter(partitionIDs, func(partitionID int64, _ int) bool { return partitionID > allPartitionID }) validPartitions := lo.Filter(partitionIDs, func(partitionID int64, _ int) bool { return partitionID > allPartitionID })
partitionSet := typeutil.NewUniqueSet(validPartitions...) partitionSet := typeutil.NewUniqueSet(validPartitions...)
for _, s := range segments { for _, s := range segments {
if (partitionSet.Len() > 0 && !partitionSet.Contain(s.PartitionID) && s.GetPartitionID() != common.InvalidPartitionID) || if (partitionSet.Len() > 0 && !partitionSet.Contain(s.PartitionID) && s.GetPartitionID() != common.AllPartitionsID) ||
(s.GetStartPosition() == nil && s.GetDmlPosition() == nil) { (s.GetStartPosition() == nil && s.GetDmlPosition() == nil) {
continue continue
} }

View File

@ -1530,7 +1530,7 @@ func TestGetQueryVChanPositions(t *testing.T) {
s4 := &datapb.SegmentInfo{ s4 := &datapb.SegmentInfo{
ID: 4, ID: 4,
CollectionID: 0, CollectionID: 0,
PartitionID: common.InvalidPartitionID, PartitionID: common.AllPartitionsID,
InsertChannel: "ch1", InsertChannel: "ch1",
State: commonpb.SegmentState_Flushed, State: commonpb.SegmentState_Flushed,
StartPosition: &msgpb.MsgPosition{ StartPosition: &msgpb.MsgPosition{

View File

@ -63,7 +63,7 @@ func (f SegmentFilterFunc) SegmentIDs() ([]int64, bool) {
func WithPartitionID(partitionID int64) SegmentFilter { func WithPartitionID(partitionID int64) SegmentFilter {
return SegmentFilterFunc(func(info *SegmentInfo) bool { return SegmentFilterFunc(func(info *SegmentInfo) bool {
return partitionID == common.InvalidPartitionID || info.partitionID == partitionID return partitionID == common.AllPartitionsID || info.partitionID == partitionID
}) })
} }

View File

@ -53,7 +53,7 @@ func (wb *bfWriteBuffer) dispatchDeleteMsgs(groups []*inData, deleteMsgs []*msgs
} }
for _, inData := range groups { for _, inData := range groups {
if delMsg.GetPartitionID() == common.InvalidPartitionID || delMsg.GetPartitionID() == inData.partitionID { if delMsg.GetPartitionID() == common.AllPartitionsID || delMsg.GetPartitionID() == inData.partitionID {
var deletePks []storage.PrimaryKey var deletePks []storage.PrimaryKey
var deleteTss []typeutil.Timestamp var deleteTss []typeutil.Timestamp
for idx, pk := range pks { for idx, pk := range pks {

View File

@ -71,7 +71,7 @@ func (wb *l0WriteBuffer) dispatchDeleteMsgs(groups []*inData, deleteMsgs []*msgs
} }
for _, inData := range groups { for _, inData := range groups {
if delMsg.GetPartitionID() == common.InvalidPartitionID || delMsg.GetPartitionID() == inData.partitionID { if delMsg.GetPartitionID() == common.AllPartitionsID || delMsg.GetPartitionID() == inData.partitionID {
var deletePks []storage.PrimaryKey var deletePks []storage.PrimaryKey
var deleteTss []typeutil.Timestamp var deleteTss []typeutil.Timestamp
for idx, pk := range pks { for idx, pk := range pks {

View File

@ -267,7 +267,7 @@ func (dr *deleteRunner) Init(ctx context.Context) error {
dr.partitionKeyMode = dr.schema.IsPartitionKeyCollection() dr.partitionKeyMode = dr.schema.IsPartitionKeyCollection()
// get partitionIDs of delete // get partitionIDs of delete
dr.partitionID = common.InvalidPartitionID dr.partitionID = common.AllPartitionsID
if len(dr.req.PartitionName) > 0 { if len(dr.req.PartitionName) > 0 {
if dr.partitionKeyMode { if dr.partitionKeyMode {
return errors.New("not support manually specifying the partition names if partition key mode is used") return errors.New("not support manually specifying the partition names if partition key mode is used")

View File

@ -245,7 +245,7 @@ func (it *upsertTask) deletePreExecute(ctx context.Context) error {
// multi entities with same pk and diff partition keys may be hashed to multi physical partitions // multi entities with same pk and diff partition keys may be hashed to multi physical partitions
// if deleteMsg.partitionID = common.InvalidPartition, // if deleteMsg.partitionID = common.InvalidPartition,
// all segments with this pk under the collection will have the delete record // all segments with this pk under the collection will have the delete record
it.upsertMsg.DeleteMsg.PartitionID = common.InvalidPartitionID it.upsertMsg.DeleteMsg.PartitionID = common.AllPartitionsID
} else { } else {
// partition name could be defaultPartitionName or name specified by sdk // partition name could be defaultPartitionName or name specified by sdk
partName := it.upsertMsg.DeleteMsg.PartitionName partName := it.upsertMsg.DeleteMsg.PartitionName

View File

@ -231,7 +231,7 @@ func (mgr *TargetManager) PullNextTargetV2(broker Broker, collectionID int64, ch
partitionSet := typeutil.NewUniqueSet(chosenPartitionIDs...) partitionSet := typeutil.NewUniqueSet(chosenPartitionIDs...)
for _, segmentInfo := range segmentInfos { for _, segmentInfo := range segmentInfos {
if partitionSet.Contain(segmentInfo.GetPartitionID()) || segmentInfo.GetPartitionID() == common.InvalidPartitionID { if partitionSet.Contain(segmentInfo.GetPartitionID()) || segmentInfo.GetPartitionID() == common.AllPartitionsID {
segments[segmentInfo.GetID()] = segmentInfo segments[segmentInfo.GetID()] = segmentInfo
} }
} }

View File

@ -481,7 +481,7 @@ func (sd *shardDelegator) LoadSegments(ctx context.Context, req *querypb.LoadSeg
func (sd *shardDelegator) GetLevel0Deletions(partitionID int64) ([]storage.PrimaryKey, []storage.Timestamp) { func (sd *shardDelegator) GetLevel0Deletions(partitionID int64) ([]storage.PrimaryKey, []storage.Timestamp) {
sd.level0Mut.RLock() sd.level0Mut.RLock()
deleteData, ok1 := sd.level0Deletions[partitionID] deleteData, ok1 := sd.level0Deletions[partitionID]
allPartitionsDeleteData, ok2 := sd.level0Deletions[common.InvalidPartitionID] allPartitionsDeleteData, ok2 := sd.level0Deletions[common.AllPartitionsID]
sd.level0Mut.RUnlock() sd.level0Mut.RUnlock()
// we may need to merge the specified partition deletions and the all partitions deletions, // we may need to merge the specified partition deletions and the all partitions deletions,
// so release the mutex as early as possible. // so release the mutex as early as possible.
@ -647,7 +647,7 @@ func (sd *shardDelegator) loadStreamDelete(ctx context.Context,
deleteRecords := sd.deleteBuffer.ListAfter(position.GetTimestamp()) deleteRecords := sd.deleteBuffer.ListAfter(position.GetTimestamp())
for _, entry := range deleteRecords { for _, entry := range deleteRecords {
for _, record := range entry.Data { for _, record := range entry.Data {
if record.PartitionID != common.InvalidPartitionID && candidate.Partition() != record.PartitionID { if record.PartitionID != common.AllPartitionsID && candidate.Partition() != record.PartitionID {
continue continue
} }
for i, pk := range record.DeleteData.Pks { for i, pk := range record.DeleteData.Pks {

View File

@ -1002,7 +1002,7 @@ func (s *DelegatorDataSuite) TestLevel0Deletions() {
pks, _ = delegator.GetLevel0Deletions(partitionID + 1) pks, _ = delegator.GetLevel0Deletions(partitionID + 1)
s.Empty(pks) s.Empty(pks)
delegator.level0Deletions[common.InvalidPartitionID] = allPartitionDeleteData delegator.level0Deletions[common.AllPartitionsID] = allPartitionDeleteData
pks, _ = delegator.GetLevel0Deletions(partitionID) pks, _ = delegator.GetLevel0Deletions(partitionID)
s.Len(pks, 2) s.Len(pks, 2)
s.True(pks[0].EQ(partitionDeleteData.Pks[0])) s.True(pks[0].EQ(partitionDeleteData.Pks[0]))
@ -1023,7 +1023,7 @@ func (s *DelegatorDataSuite) TestLevel0Deletions() {
pks, _ = delegator.GetLevel0Deletions(partitionID + 1) pks, _ = delegator.GetLevel0Deletions(partitionID + 1)
s.Empty(pks) s.Empty(pks)
delegator.level0Deletions[common.InvalidPartitionID] = allPartitionDeleteData delegator.level0Deletions[common.AllPartitionsID] = allPartitionDeleteData
pks, _ = delegator.GetLevel0Deletions(partitionID) pks, _ = delegator.GetLevel0Deletions(partitionID)
s.Len(pks, 2) s.Len(pks, 2)
s.True(pks[0].EQ(allPartitionDeleteData.Pks[0])) s.True(pks[0].EQ(allPartitionDeleteData.Pks[0]))

View File

@ -67,6 +67,6 @@ func WithSegmentIDs(segmentIDs ...int64) CandidateFilter {
// WithPartitionID returns CandidateFilter with provided partitionID. // WithPartitionID returns CandidateFilter with provided partitionID.
func WithPartitionID(partitionID int64) CandidateFilter { func WithPartitionID(partitionID int64) CandidateFilter {
return func(candidate candidateWithWorker) bool { return func(candidate candidateWithWorker) bool {
return candidate.Partition() == partitionID || partitionID == common.InvalidPartitionID return candidate.Partition() == partitionID || partitionID == common.AllPartitionsID
} }
} }

View File

@ -59,6 +59,9 @@ const (
// InvalidPartitionID indicates that the partition is not specified. It will be set when the partitionName is empty // InvalidPartitionID indicates that the partition is not specified. It will be set when the partitionName is empty
InvalidPartitionID = int64(-1) InvalidPartitionID = int64(-1)
// AllPartitionsID indicates data applies to all partitions.
AllPartitionsID = int64(-1)
// InvalidFieldID indicates that the field does not exist . It will be set when the field is not found. // InvalidFieldID indicates that the field does not exist . It will be set when the field is not found.
InvalidFieldID = int64(-1) InvalidFieldID = int64(-1)