enhance: add the skip auto id and partition key check config (#32592)

/kind improvement
issue: #32591

Signed-off-by: SimFG <bang.fu@zilliz.com>
pull/32686/head
SimFG 2024-04-29 10:29:26 +08:00 committed by GitHub
parent 84a14fa8dc
commit 09cd56d44f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 33 additions and 2 deletions

View File

@ -1190,7 +1190,12 @@ func checkPrimaryFieldData(schema *schemapb.CollectionSchema, result *milvuspb.M
var primaryFieldData *schemapb.FieldData var primaryFieldData *schemapb.FieldData
if inInsert { if inInsert {
// when checkPrimaryFieldData in insert // when checkPrimaryFieldData in insert
if !primaryFieldSchema.AutoID {
skipAutoIDCheck := Params.ProxyCfg.SkipAutoIDCheck.GetAsBool() &&
primaryFieldSchema.AutoID &&
typeutil.IsPrimaryFieldDataExist(insertMsg.GetFieldsData(), primaryFieldSchema)
if !primaryFieldSchema.AutoID || skipAutoIDCheck {
primaryFieldData, err = typeutil.GetPrimaryFieldData(insertMsg.GetFieldsData(), primaryFieldSchema) primaryFieldData, err = typeutil.GetPrimaryFieldData(insertMsg.GetFieldsData(), primaryFieldSchema)
if err != nil { if err != nil {
log.Info("get primary field data failed", zap.String("collectionName", insertMsg.CollectionName), zap.Error(err)) log.Info("get primary field data failed", zap.String("collectionName", insertMsg.CollectionName), zap.Error(err))
@ -1239,7 +1244,7 @@ func checkPrimaryFieldData(schema *schemapb.CollectionSchema, result *milvuspb.M
} }
func getPartitionKeyFieldData(fieldSchema *schemapb.FieldSchema, insertMsg *msgstream.InsertMsg) (*schemapb.FieldData, error) { func getPartitionKeyFieldData(fieldSchema *schemapb.FieldSchema, insertMsg *msgstream.InsertMsg) (*schemapb.FieldData, error) {
if len(insertMsg.GetPartitionName()) > 0 { if len(insertMsg.GetPartitionName()) > 0 && !Params.ProxyCfg.SkipPartitionKeyCheck.GetAsBool() {
return nil, errors.New("not support manually specifying the partition names if partition key mode is used") return nil, errors.New("not support manually specifying the partition names if partition key mode is used")
} }

View File

@ -1012,6 +1012,8 @@ type proxyConfig struct {
RetryTimesOnHealthCheck ParamItem `refreshable:"true"` RetryTimesOnHealthCheck ParamItem `refreshable:"true"`
PartitionNameRegexp ParamItem `refreshable:"true"` PartitionNameRegexp ParamItem `refreshable:"true"`
MustUsePartitionKey ParamItem `refreshable:"true"` MustUsePartitionKey ParamItem `refreshable:"true"`
SkipAutoIDCheck ParamItem `refreshable:"true"`
SkipPartitionKeyCheck ParamItem `refreshable:"true"`
AccessLog AccessLogConfig AccessLog AccessLogConfig
@ -1348,6 +1350,22 @@ please adjust in embedded Milvus: false`,
} }
p.MustUsePartitionKey.Init(base.mgr) p.MustUsePartitionKey.Init(base.mgr)
p.SkipAutoIDCheck = ParamItem{
Key: "proxy.skipAutoIDCheck",
Version: "2.4.1",
DefaultValue: "false",
Doc: "switch for whether proxy shall skip auto id check when inserting data",
}
p.SkipAutoIDCheck.Init(base.mgr)
p.SkipPartitionKeyCheck = ParamItem{
Key: "proxy.skipPartitionKeyCheck",
Version: "2.4.1",
DefaultValue: "false",
Doc: "switch for whether proxy shall skip partition key check when inserting data",
}
p.SkipPartitionKeyCheck.Init(base.mgr)
p.GracefulStopTimeout = ParamItem{ p.GracefulStopTimeout = ParamItem{
Key: "proxy.gracefulStopTimeout", Key: "proxy.gracefulStopTimeout",
Version: "2.3.7", Version: "2.3.7",

View File

@ -174,6 +174,14 @@ func TestComponentParam(t *testing.T) {
assert.False(t, Params.MustUsePartitionKey.GetAsBool()) assert.False(t, Params.MustUsePartitionKey.GetAsBool())
params.Save("proxy.mustUsePartitionKey", "true") params.Save("proxy.mustUsePartitionKey", "true")
assert.True(t, Params.MustUsePartitionKey.GetAsBool()) assert.True(t, Params.MustUsePartitionKey.GetAsBool())
assert.False(t, Params.SkipAutoIDCheck.GetAsBool())
params.Save("proxy.skipAutoIDCheck", "true")
assert.True(t, Params.SkipAutoIDCheck.GetAsBool())
assert.False(t, Params.SkipPartitionKeyCheck.GetAsBool())
params.Save("proxy.skipPartitionKeyCheck", "true")
assert.True(t, Params.SkipPartitionKeyCheck.GetAsBool())
}) })
// t.Run("test proxyConfig panic", func(t *testing.T) { // t.Run("test proxyConfig panic", func(t *testing.T) {