Skip to content

Commit

Permalink
domain: do not start Auto Analyze Worker until statistics initializat…
Browse files Browse the repository at this point in the history
…ion is complete (#52407)

close #52346
  • Loading branch information
Rustin170506 authored Apr 11, 2024
1 parent 2debbed commit 0f23d83
Showing 1 changed file with 19 additions and 2 deletions.
21 changes: 19 additions & 2 deletions pkg/domain/domain.go
Original file line number Diff line number Diff line change
Expand Up @@ -2228,9 +2228,26 @@ func (do *Domain) UpdateTableStatsLoop(ctx, initStatsCtx sessionctx.Context) err
return nil
}
do.SetStatsUpdating(true)
// The stats updated worker doesn't require the stats initialization to be completed.
// This is because the updated worker's primary responsibilities are to update the change delta and handle DDL operations.
// These tasks do not interfere with or depend on the initialization process.
do.wg.Run(func() { do.updateStatsWorker(ctx, owner) }, "updateStatsWorker")
do.wg.Run(func() { do.autoAnalyzeWorker(owner) }, "autoAnalyzeWorker")
do.wg.Run(func() { do.analyzeJobsCleanupWorker(owner) }, "analyzeJobsCleanupWorker")
// Wait for the stats worker to finish the initialization.
// Otherwise, we may start the auto analyze worker before the stats cache is initialized.
do.wg.Run(
func() {
<-do.StatsHandle().InitStatsDone
do.autoAnalyzeWorker(owner)
},
"autoAnalyzeWorker",
)
do.wg.Run(
func() {
<-do.StatsHandle().InitStatsDone
do.analyzeJobsCleanupWorker(owner)
},
"analyzeJobsCleanupWorker",
)
return nil
}

Expand Down

0 comments on commit 0f23d83

Please sign in to comment.