From da14ce7ddda79d056357e682a633b7660c0ae2bb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=8E=8B=E8=B6=85?= Date: Tue, 29 Oct 2024 11:59:31 +0800 Subject: [PATCH] *: make table id in `metrics_schema` stable (#56839) close pingcap/tidb#56775 --- pkg/infoschema/metrics_schema.go | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/pkg/infoschema/metrics_schema.go b/pkg/infoschema/metrics_schema.go index b6d5a304eb7f8..4c3f8b99e0d6f 100644 --- a/pkg/infoschema/metrics_schema.go +++ b/pkg/infoschema/metrics_schema.go @@ -41,19 +41,27 @@ const ( func init() { // Initialize the metric schema database and register the driver to `drivers`. dbID := autoid.MetricSchemaDBID - tableID := dbID + 1 metricTables := make([]*model.TableInfo, 0, len(MetricTableMap)) for name, def := range MetricTableMap { cols := def.genColumnInfos() tableInfo := buildTableMeta(name, cols) - tableInfo.ID = tableID tableInfo.Comment = def.Comment tableInfo.DBID = dbID - tableID++ metricTables = append(metricTables, tableInfo) tableInfo.MaxColumnID = int64(len(tableInfo.Columns)) tableInfo.MaxIndexID = int64(len(tableInfo.Indices)) } + + // assign table IDs, sort by table name first to make the id stable across different TiDB instances. + slices.SortFunc(metricTables, func(a, b *model.TableInfo) int { + return strings.Compare(a.Name.L, b.Name.L) + }) + tableID := dbID + 1 + for _, tableInfo := range metricTables { + tableInfo.ID = tableID + tableID++ + } + dbInfo := &model.DBInfo{ ID: dbID, Name: pmodel.NewCIStr(util.MetricSchemaName.O),