mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-04 13:52:05 +01:00
dc9eafcd02
This option can be useful when samples for the same time series are ingested with distinct order of labels. For example, metric{k1="v1",k2="v2"} and metric{k2="v2",k1="v1"}.
33 lines
935 B
Go
33 lines
935 B
Go
package common
|
|
|
|
import (
|
|
"flag"
|
|
"sort"
|
|
|
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/prompb"
|
|
)
|
|
|
|
var sortLabels = flag.Bool("sortLabels", false, `Whether to sort labels for incoming samples before writing them to storage. `+
|
|
`This may be needed for reducing memory usage at storage when the order of labels in incoming samples is random. `+
|
|
`For example, if m{k1="v1",k2="v2"} may be sent as m{k2="v2",k1="v1"}. `+
|
|
`Enabled sorting for labels can slow down ingestion performance a bit`)
|
|
|
|
// SortLabelsIfNeeded sorts labels if -sortLabels command-line flag is set
|
|
func (ctx *InsertCtx) SortLabelsIfNeeded() {
|
|
if *sortLabels {
|
|
sort.Sort(&ctx.Labels)
|
|
}
|
|
}
|
|
|
|
type sortedLabels []prompb.Label
|
|
|
|
func (sl *sortedLabels) Len() int { return len(*sl) }
|
|
func (sl *sortedLabels) Less(i, j int) bool {
|
|
a := *sl
|
|
return string(a[i].Name) < string(a[j].Name)
|
|
}
|
|
func (sl *sortedLabels) Swap(i, j int) {
|
|
a := *sl
|
|
a[i], a[j] = a[j], a[i]
|
|
}
|