From 0f32738e44b0629b86a455bccb08f0f8d04b1918 Mon Sep 17 00:00:00 2001 From: Ti Chi Robot Date: Mon, 16 Dec 2024 13:04:45 +0800 Subject: [PATCH] executor: Fix the parse problematic slow log panic issue due to empty value string (#58258) (#58271) 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 ec99a2fb539c4..9ecdfcc840cd3 100644 --- a/executor/slow_query.go +++ b/executor/slow_query.go @@ -599,6 +599,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] == '[') { @@ -612,6 +616,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 @@ -621,6 +632,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 ffbf471195bd4..f81fb5e35dbda 100644 --- a/executor/slow_query_test.go +++ b/executor/slow_query_test.go @@ -499,7 +499,7 @@ func TestSplitbyColon(t *testing.T) { { "123a", []string{"123a"}, - []string{}, + []string{""}, }, { "1a: 2b", @@ -552,9 +552,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) }