mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-20 07:19:17 +01:00
lib/logstorage: avoid calling columnsHeader.initFromBlockHeader() multiple times for the same blockSearch
This should improve performance when blockSearch.getColumnsHeader() is called multiple times
from different places of the code.
(cherry picked from commit 9e48074b59
)
This commit is contained in:
parent
f7496c17e4
commit
afe5158443
@ -113,13 +113,10 @@ type blockSearch struct {
|
||||
// sbu is used for unmarshaling local columns
|
||||
sbu stringsBlockUnmarshaler
|
||||
|
||||
// cshCached is the columnsHeader associated with the given block
|
||||
// cshCache is the columnsHeader associated with the given block
|
||||
//
|
||||
// it is initialized lazily by calling getColumnsHeader().
|
||||
cshCached columnsHeader
|
||||
|
||||
// cshInitialized is set to true if cshCached is initialized.
|
||||
cshInitialized bool
|
||||
cshCache *columnsHeader
|
||||
|
||||
// a is used for storing unmarshaled data in cshCached
|
||||
a arena
|
||||
@ -152,8 +149,10 @@ func (bs *blockSearch) reset() {
|
||||
|
||||
bs.sbu.reset()
|
||||
|
||||
bs.cshCached.reset()
|
||||
bs.cshInitialized = false
|
||||
if bs.cshCache != nil {
|
||||
putColumnsHeader(bs.cshCache)
|
||||
bs.cshCache = nil
|
||||
}
|
||||
|
||||
bs.a.reset()
|
||||
|
||||
@ -190,10 +189,11 @@ func (bs *blockSearch) search(bsw *blockSearchWork, bm *bitmap) {
|
||||
}
|
||||
|
||||
func (bs *blockSearch) getColumnsHeader() *columnsHeader {
|
||||
if !bs.cshInitialized {
|
||||
bs.cshCached.initFromBlockHeader(&bs.a, bs.bsw.p, &bs.bsw.bh)
|
||||
if bs.cshCache == nil {
|
||||
bs.cshCache = getColumnsHeader()
|
||||
bs.cshCache.initFromBlockHeader(&bs.a, bs.bsw.p, &bs.bsw.bh)
|
||||
}
|
||||
return &bs.cshCached
|
||||
return bs.cshCache
|
||||
}
|
||||
|
||||
func (csh *columnsHeader) initFromBlockHeader(a *arena, p *part, bh *blockHeader) {
|
||||
|
Loading…
Reference in New Issue
Block a user