mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-20 07:19:17 +01:00
app/vmselect/netstorage: limit the size of metricNamesBuf to 32Kb in order to avoid slow path at Go runtime for allocating a byte slice of bigger size
See704401ffa0/src/runtime/malloc.go (L11)
This also reduces the average memory usage a bit for vmselect and single-node VictoriaMetrics after the commit508c608062
Updates https://github.com/VictoriaMetrics/VictoriaMetrics/pull/5527
This commit is contained in:
parent
fac7c30f4e
commit
1f1768d7af
@ -1227,6 +1227,11 @@ func ProcessSearchQuery(qt *querytracer.Tracer, sq *storage.SearchQuery, deadlin
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
if len(brs.brs) == 1 {
|
if len(brs.brs) == 1 {
|
||||||
|
if cap(metricNamesBuf) >= maxFastAllocBlockSize && len(metricNamesBuf)+len(metricName) > cap(metricNamesBuf) {
|
||||||
|
// Allocate a new metricNamesBuf in order to avoid slow allocation of byte slice
|
||||||
|
// bigger than maxFastAllocBlockSize bytes at append() below.
|
||||||
|
metricNamesBuf = make([]byte, 0, maxFastAllocBlockSize)
|
||||||
|
}
|
||||||
metricNamesBufLen := len(metricNamesBuf)
|
metricNamesBufLen := len(metricNamesBuf)
|
||||||
metricNamesBuf = append(metricNamesBuf, metricName...)
|
metricNamesBuf = append(metricNamesBuf, metricName...)
|
||||||
metricNameStr := bytesutil.ToUnsafeString(metricNamesBuf[metricNamesBufLen:])
|
metricNameStr := bytesutil.ToUnsafeString(metricNamesBuf[metricNamesBufLen:])
|
||||||
@ -1235,6 +1240,7 @@ func ProcessSearchQuery(qt *querytracer.Tracer, sq *storage.SearchQuery, deadlin
|
|||||||
m[metricNameStr] = brsIdx
|
m[metricNameStr] = brsIdx
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := sr.Error(); err != nil {
|
if err := sr.Error(); err != nil {
|
||||||
putTmpBlocksFile(tbf)
|
putTmpBlocksFile(tbf)
|
||||||
putStorageSearch(sr)
|
putStorageSearch(sr)
|
||||||
@ -1324,3 +1330,8 @@ func applyGraphiteRegexpFilter(filter string, ss []string) ([]string, error) {
|
|||||||
}
|
}
|
||||||
return dst, nil
|
return dst, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Go uses fast allocations for block sizes up to 32Kb.
|
||||||
|
//
|
||||||
|
// See https://github.com/golang/go/blob/704401ffa06c60e059c9e6e4048045b4ff42530a/src/runtime/malloc.go#L11
|
||||||
|
const maxFastAllocBlockSize = 32*1024
|
||||||
|
Loading…
Reference in New Issue
Block a user