From 6d055365213423910c215560db456da95cbc858d Mon Sep 17 00:00:00 2001 From: Ti Chi Robot Date: Mon, 16 Dec 2024 12:24:24 +0800 Subject: [PATCH] executor: Fix the parse problematic slow log panic issue due to empty value string (#58258) (#58270) close pingcap/tidb#58147 --- executor/slow_query.go | 15 +++++++++++++++ executor/slow_query_test.go | 9 ++++++++- 2 files changed, 23 insertions(+), 1 deletion(-) diff --git a/executor/slow_query.go b/executor/slow_query.go index 76b2c10ab8d50..9900ed61a41ee 100644 --- a/executor/slow_query.go +++ b/executor/slow_query.go @@ -575,6 +575,10 @@ func splitByColon(line string) (fields []string, values []string) { fields = append(fields, line[start:current]) parseKey = false current += 2 // bypass ": " + if current >= lineLength { + // last empty value + values = append(values, "") + } } else { start = current if current < lineLength && (line[current] == '{' || line[current] == '[') { @@ -588,6 +592,13 @@ func splitByColon(line string) (fields []string, values []string) { for current < lineLength && line[current] != ' ' { current++ } + // Meet empty value cases: "Key: Key:" + if current > 0 && line[current-1] == ':' { + values = append(values, "") + current = start + parseKey = true + continue + } } values = append(values, line[start:mathutil.Min(current, len(line))]) parseKey = true @@ -597,6 +608,10 @@ func splitByColon(line string) (fields []string, values []string) { logutil.BgLogger().Warn("slow query parse slow log error", zap.String("Error", errMsg), zap.String("Log", line)) return nil, nil } + if len(fields) != len(values) { + logutil.BgLogger().Warn("slow query parse slow log error", zap.Int("field_count", len(fields)), zap.Int("value_count", len(values)), zap.String("Log", line)) + return nil, nil + } return fields, values } diff --git a/executor/slow_query_test.go b/executor/slow_query_test.go index 6798ac855056f..389cd06afde3a 100644 --- a/executor/slow_query_test.go +++ b/executor/slow_query_test.go @@ -504,7 +504,7 @@ func TestSplitbyColon(t *testing.T) { { "123a", []string{"123a"}, - []string{}, + []string{""}, }, { "1a: 2b", @@ -557,9 +557,16 @@ func TestSplitbyColon(t *testing.T) { []string{"Time"}, []string{"2021-09-08T14:39:54.506967433+08:00"}, }, + { + + "Cop_proc_avg: 0 Cop_proc_addr: Cop_proc_max: Cop_proc_min: ", + []string{"Cop_proc_avg", "Cop_proc_addr", "Cop_proc_max", "Cop_proc_min"}, + []string{"0", "", "", ""}, + }, } for _, c := range cases { resFields, resValues := splitByColon(c.line) + logutil.BgLogger().Info(c.line) require.Equal(t, c.fields, resFields) require.Equal(t, c.values, resValues) }