forked from pingcap/tidb
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathanalyze_jobs.go
91 lines (82 loc) · 2.63 KB
/
analyze_jobs.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
// Copyright 2019 PingCAP, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package statistics
import (
"sync"
"time"
)
// AnalyzeJob is used to represent the status of one analyze job.
type AnalyzeJob struct {
ID *uint64
DBName string
TableName string
PartitionName string
JobInfo string
StartTime time.Time
EndTime time.Time
Progress AnalyzeProgress
}
// AnalyzeProgress represents the process of one analyze job.
type AnalyzeProgress struct {
sync.Mutex
// deltaCount is the newly processed rows after the last time mysql.analyze_jobs.processed_rows is updated.
deltaCount int64
// lastDumpTime is the last time mysql.analyze_jobs.processed_rows is updated.
lastDumpTime time.Time
}
// Update adds rowCount to the delta count. If the updated delta count reaches threshold, it returns the delta count for
// dumping it into mysql.analyze_jobs and resets the delta count to 0. Otherwise it returns 0.
func (p *AnalyzeProgress) Update(rowCount int64) (dumpCount int64) {
p.Lock()
defer p.Unlock()
p.deltaCount += rowCount
t := time.Now()
const maxDelta int64 = 10000000
const dumpTimeInterval = 5 * time.Second
if p.deltaCount > maxDelta && t.Sub(p.lastDumpTime) > dumpTimeInterval {
dumpCount = p.deltaCount
p.deltaCount = 0
p.lastDumpTime = t
return
}
return
}
// GetDeltaCount returns the delta count which hasn't been dumped into mysql.analyze_jobs.
func (p *AnalyzeProgress) GetDeltaCount() int64 {
p.Lock()
defer p.Unlock()
return p.deltaCount
}
// SetLastDumpTime sets the last dump time.
func (p *AnalyzeProgress) SetLastDumpTime(t time.Time) {
p.Lock()
defer p.Unlock()
p.lastDumpTime = t
}
// GetLastDumpTime returns the last dump time.
func (p *AnalyzeProgress) GetLastDumpTime() time.Time {
p.Lock()
defer p.Unlock()
return p.lastDumpTime
}
const (
// AnalyzePending means the analyze job is pending
AnalyzePending = "pending"
// AnalyzeRunning means the analyze job is running
AnalyzeRunning = "running"
// AnalyzeFinished means the analyze job has finished
AnalyzeFinished = "finished"
// AnalyzeFailed means the analyze job has failed
AnalyzeFailed = "failed"
)