mirror of https://github.com/prometheus/prometheus
web/api: optimize labelnames/values with 1 set of matchers (#12888)
* web/api: optimize labelnames/values with 1 set of matchers If there is exactly one set of matchers provided, we can skip adding the results to a map and getting them back out again. Signed-off-by: Bryan Boreham <bjboreham@gmail.com> --------- Signed-off-by: Bryan Boreham <bjboreham@gmail.com>pull/13137/head
parent
37573d083b
commit
41758972e4
|
@ -668,7 +668,7 @@ func (api *API) labelNames(r *http.Request) apiFuncResult {
|
||||||
names []string
|
names []string
|
||||||
warnings annotations.Annotations
|
warnings annotations.Annotations
|
||||||
)
|
)
|
||||||
if len(matcherSets) > 0 {
|
if len(matcherSets) > 1 {
|
||||||
labelNamesSet := make(map[string]struct{})
|
labelNamesSet := make(map[string]struct{})
|
||||||
|
|
||||||
for _, matchers := range matcherSets {
|
for _, matchers := range matcherSets {
|
||||||
|
@ -690,7 +690,11 @@ func (api *API) labelNames(r *http.Request) apiFuncResult {
|
||||||
}
|
}
|
||||||
slices.Sort(names)
|
slices.Sort(names)
|
||||||
} else {
|
} else {
|
||||||
names, warnings, err = q.LabelNames(r.Context())
|
var matchers []*labels.Matcher
|
||||||
|
if len(matcherSets) == 1 {
|
||||||
|
matchers = matcherSets[0]
|
||||||
|
}
|
||||||
|
names, warnings, err = q.LabelNames(r.Context(), matchers...)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return apiFuncResult{nil, &apiError{errorExec, err}, warnings, nil}
|
return apiFuncResult{nil, &apiError{errorExec, err}, warnings, nil}
|
||||||
}
|
}
|
||||||
|
@ -744,7 +748,7 @@ func (api *API) labelValues(r *http.Request) (result apiFuncResult) {
|
||||||
vals []string
|
vals []string
|
||||||
warnings annotations.Annotations
|
warnings annotations.Annotations
|
||||||
)
|
)
|
||||||
if len(matcherSets) > 0 {
|
if len(matcherSets) > 1 {
|
||||||
var callWarnings annotations.Annotations
|
var callWarnings annotations.Annotations
|
||||||
labelValuesSet := make(map[string]struct{})
|
labelValuesSet := make(map[string]struct{})
|
||||||
for _, matchers := range matcherSets {
|
for _, matchers := range matcherSets {
|
||||||
|
@ -763,7 +767,11 @@ func (api *API) labelValues(r *http.Request) (result apiFuncResult) {
|
||||||
vals = append(vals, val)
|
vals = append(vals, val)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
vals, warnings, err = q.LabelValues(ctx, name)
|
var matchers []*labels.Matcher
|
||||||
|
if len(matcherSets) == 1 {
|
||||||
|
matchers = matcherSets[0]
|
||||||
|
}
|
||||||
|
vals, warnings, err = q.LabelValues(ctx, name, matchers...)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return apiFuncResult{nil, &apiError{errorExec, err}, warnings, closer}
|
return apiFuncResult{nil, &apiError{errorExec, err}, warnings, closer}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue