mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-11 05:47:27 -08:00
promql: optimise aggregation with no labels
For a query like 'sum (foo)', we can quickly skip to the empty labels that its result needs. Signed-off-by: Bryan Boreham <bjboreham@gmail.com>
This commit is contained in:
parent
aafef011b7
commit
1b0a29701b
|
@ -2384,14 +2384,18 @@ func (ev *evaluator) aggregation(op parser.ItemType, grouping []string, without
|
||||||
group, ok := result[groupingKey]
|
group, ok := result[groupingKey]
|
||||||
// Add a new group if it doesn't exist.
|
// Add a new group if it doesn't exist.
|
||||||
if !ok {
|
if !ok {
|
||||||
|
var m labels.Labels
|
||||||
enh.resetBuilder(metric)
|
enh.resetBuilder(metric)
|
||||||
if without {
|
if without {
|
||||||
enh.lb.Del(grouping...)
|
enh.lb.Del(grouping...)
|
||||||
enh.lb.Del(labels.MetricName)
|
enh.lb.Del(labels.MetricName)
|
||||||
} else {
|
m = enh.lb.Labels(labels.EmptyLabels())
|
||||||
|
} else if len(grouping) > 0 {
|
||||||
enh.lb.Keep(grouping...)
|
enh.lb.Keep(grouping...)
|
||||||
|
m = enh.lb.Labels(labels.EmptyLabels())
|
||||||
|
} else {
|
||||||
|
m = labels.EmptyLabels()
|
||||||
}
|
}
|
||||||
m := enh.lb.Labels(labels.EmptyLabels())
|
|
||||||
newAgg := &groupedAggregation{
|
newAgg := &groupedAggregation{
|
||||||
labels: m,
|
labels: m,
|
||||||
value: s.V,
|
value: s.V,
|
||||||
|
|
Loading…
Reference in a new issue