From 6dd6a5e50cd3faf6a0dbc3b26551ba3fe1f8b16e Mon Sep 17 00:00:00 2001 From: Weizhen Wang Date: Thu, 26 Oct 2023 14:27:34 +0800 Subject: [PATCH] executor: improve channel length for analyze (#47960) ref pingcap/tidb#47275 --- pkg/executor/analyze.go | 3 +-- pkg/executor/analyze_col_v2.go | 4 ++-- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/pkg/executor/analyze.go b/pkg/executor/analyze.go index ddfff2f77519c..26acb9ce56bca 100644 --- a/pkg/executor/analyze.go +++ b/pkg/executor/analyze.go @@ -108,8 +108,7 @@ func (e *AnalyzeExec) Next(ctx context.Context, _ *chunk.Chunk) error { // Start workers with channel to collect results. taskCh := make(chan *analyzeTask, concurrency) - resultChLen := min(concurrency*2, len(tasks)) - resultsCh := make(chan *statistics.AnalyzeResults, resultChLen) + resultsCh := make(chan *statistics.AnalyzeResults, 1) for i := 0; i < concurrency; i++ { e.wg.Run(func() { e.analyzeWorker(taskCh, resultsCh) }) } diff --git a/pkg/executor/analyze_col_v2.go b/pkg/executor/analyze_col_v2.go index 40a96efec1afa..6faa8e0f529a4 100644 --- a/pkg/executor/analyze_col_v2.go +++ b/pkg/executor/analyze_col_v2.go @@ -275,8 +275,8 @@ func (e *AnalyzeColumnsExecV2) buildSamplingStats( sc := e.ctx.GetSessionVars().StmtCtx // Start workers to merge the result from collectors. - mergeResultCh := make(chan *samplingMergeResult, samplingStatsConcurrency) - mergeTaskCh := make(chan []byte, samplingStatsConcurrency) + mergeResultCh := make(chan *samplingMergeResult, 1) + mergeTaskCh := make(chan []byte, 1) var taskEg errgroup.Group // Start read data from resultHandler and send them to mergeTaskCh. taskEg.Go(func() (err error) {