diff --git a/pkg/cluster/api/pdapi.go b/pkg/cluster/api/pdapi.go index d4ea9a555a..d0e2ca5308 100644 --- a/pkg/cluster/api/pdapi.go +++ b/pkg/cluster/api/pdapi.go @@ -692,18 +692,18 @@ func (pc *PDClient) GetReplicateConfig() ([]byte, error) { } // GetLocationLabels gets the replication.location-labels config from pd server -func (pc *PDClient) GetLocationLabels() ([]string, error) { +func (pc *PDClient) GetLocationLabels() ([]string, bool, error) { config, err := pc.GetReplicateConfig() if err != nil { - return nil, err + return nil, false, err } rc := PDReplicationConfig{} if err := json.Unmarshal(config, &rc); err != nil { - return nil, perrs.Annotatef(err, "unmarshal replication config: %s", string(config)) + return nil, false, perrs.Annotatef(err, "unmarshal replication config: %s", string(config)) } - return rc.LocationLabels, nil + return rc.LocationLabels, rc.EnablePlacementRules, nil } // GetTiKVLabels implements TiKVLabelProvider diff --git a/pkg/cluster/manager/display.go b/pkg/cluster/manager/display.go index 656908f496..9c1b5cd981 100644 --- a/pkg/cluster/manager/display.go +++ b/pkg/cluster/manager/display.go @@ -138,10 +138,13 @@ func (m *Manager) Display(name string, opt operator.Options) error { if t, ok := topo.(*spec.Specification); ok { // Check if TiKV's label set correctly pdClient := api.NewPDClient(masterActive, 10*time.Second, tlsCfg) - if lbs, err := pdClient.GetLocationLabels(); err != nil { + + if lbs, placementRule, err := pdClient.GetLocationLabels(); err != nil { log.Debugf("get location labels from pd failed: %v", err) - } else if err := spec.CheckTiKVLabels(lbs, pdClient); err != nil { - color.Yellow("\nWARN: there is something wrong with TiKV labels, which may cause data losing:\n%v", err) + } else if !placementRule { + if err := spec.CheckTiKVLabels(lbs, pdClient); err != nil { + color.Yellow("\nWARN: there is something wrong with TiKV labels, which may cause data losing:\n%v", err) + } } // Check if there is some instance in tombstone state diff --git a/pkg/cluster/manager/scale_out.go b/pkg/cluster/manager/scale_out.go index 03a218be6d..c5eef1e0d3 100644 --- a/pkg/cluster/manager/scale_out.go +++ b/pkg/cluster/manager/scale_out.go @@ -88,12 +88,14 @@ func (m *Manager) ScaleOut( return err } pdClient := api.NewPDClient(pdList, 10*time.Second, tlsCfg) - lbs, err := pdClient.GetLocationLabels() + lbs, placementRule, err := pdClient.GetLocationLabels() if err != nil { return err } - if err := spec.CheckTiKVLabels(lbs, mergedTopo.(*spec.Specification)); err != nil { - return perrs.Errorf("check TiKV label failed, please fix that before continue:\n%s", err) + if !placementRule { + if err := spec.CheckTiKVLabels(lbs, mergedTopo.(*spec.Specification)); err != nil { + return perrs.Errorf("check TiKV label failed, please fix that before continue:\n%s", err) + } } }