mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-20 15:16:42 +00:00
wip
This commit is contained in:
parent
5e61b40fef
commit
d75b0df747
1 changed files with 3 additions and 2 deletions
|
@ -258,7 +258,8 @@ func (shard *pipeTopkProcessorShard) addRow(br *blockResult, byColumns []string,
|
||||||
r.timestamp = timestamp
|
r.timestamp = timestamp
|
||||||
|
|
||||||
rows := shard.rows
|
rows := shard.rows
|
||||||
if len(rows) > 0 && !topkLess(shard.ps, r, rows[0]) {
|
maxRows := shard.ps.offset + shard.ps.limit
|
||||||
|
if uint64(len(rows)) >= maxRows && !topkLess(shard.ps, r, rows[0]) {
|
||||||
// Fast path - nothing to add.
|
// Fast path - nothing to add.
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -282,7 +283,7 @@ func (shard *pipeTopkProcessorShard) addRow(br *blockResult, byColumns []string,
|
||||||
shard.stateSizeBudget -= r.sizeBytes()
|
shard.stateSizeBudget -= r.sizeBytes()
|
||||||
|
|
||||||
// Push r to shard.rows.
|
// Push r to shard.rows.
|
||||||
if uint64(len(rows)) < shard.ps.offset+shard.ps.limit {
|
if uint64(len(rows)) < maxRows {
|
||||||
heap.Push(shard, r)
|
heap.Push(shard, r)
|
||||||
shard.stateSizeBudget -= int(unsafe.Sizeof(r))
|
shard.stateSizeBudget -= int(unsafe.Sizeof(r))
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in a new issue