mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-12 22:37:27 -08:00
Simplify QueryAnalizer.Visit().
Change-Id: I628582a1903b7273e78921e22a475f1dae5ebaae
This commit is contained in:
parent
fd63500ed3
commit
682cf6fc51
|
@ -73,8 +73,12 @@ func (analyzer *QueryAnalyzer) Visit(node Node) {
|
|||
}
|
||||
n.fingerprints = fingerprints
|
||||
for _, fingerprint := range fingerprints {
|
||||
// Only add the fingerprint to IntervalRanges if not yet present in FullRanges.
|
||||
// Full ranges always contain more points and span more time than interval ranges.
|
||||
if _, alreadyInFullRanges := analyzer.FullRanges[*fingerprint]; !alreadyInFullRanges {
|
||||
analyzer.IntervalRanges[*fingerprint] = true
|
||||
}
|
||||
}
|
||||
case *MatrixLiteral:
|
||||
fingerprints, err := analyzer.storage.GetFingerprintsForLabelSet(n.labels)
|
||||
if err != nil {
|
||||
|
@ -85,6 +89,10 @@ func (analyzer *QueryAnalyzer) Visit(node Node) {
|
|||
for _, fingerprint := range fingerprints {
|
||||
if analyzer.FullRanges[*fingerprint] < n.interval {
|
||||
analyzer.FullRanges[*fingerprint] = n.interval
|
||||
// Delete the fingerprint from IntervalRanges. Full ranges always contain
|
||||
// more points and span more time than interval ranges, so we don't need
|
||||
// an interval range for the same fingerprint, should we have one.
|
||||
delete(analyzer.IntervalRanges, *fingerprint)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -94,12 +102,6 @@ func (analyzer *QueryAnalyzer) Visit(node Node) {
|
|||
// each node to collect fingerprints.
|
||||
func (analyzer *QueryAnalyzer) AnalyzeQueries(node Node) {
|
||||
Walk(analyzer, node)
|
||||
// Find and dedupe overlaps between full and stepped ranges. Full ranges
|
||||
// always contain more points *and* span more time than stepped ranges, so
|
||||
// throw away stepped ranges for fingerprints which have full ranges.
|
||||
for fingerprint := range analyzer.FullRanges {
|
||||
delete(analyzer.IntervalRanges, fingerprint)
|
||||
}
|
||||
}
|
||||
|
||||
func viewAdapterForInstantQuery(node Node, timestamp clientmodel.Timestamp, storage *metric.TieredStorage, queryStats *stats.TimerGroup) (*viewAdapter, error) {
|
||||
|
|
Loading…
Reference in a new issue