mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2024-12-31 15:06:26 +00:00
wip
This commit is contained in:
parent
1395e222d7
commit
8248afc9bd
1 changed files with 6 additions and 1 deletions
|
@ -74,9 +74,10 @@ func (pu *pipeUnroll) updateNeededFields(neededFields, unneededFields fieldsSet)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (pu *pipeUnroll) newPipeProcessor(workersCount int, _ <-chan struct{}, _ func(), ppNext pipeProcessor) pipeProcessor {
|
func (pu *pipeUnroll) newPipeProcessor(workersCount int, stopCh <-chan struct{}, _ func(), ppNext pipeProcessor) pipeProcessor {
|
||||||
return &pipeUnrollProcessor{
|
return &pipeUnrollProcessor{
|
||||||
pu: pu,
|
pu: pu,
|
||||||
|
stopCh: stopCh,
|
||||||
ppNext: ppNext,
|
ppNext: ppNext,
|
||||||
|
|
||||||
shards: make([]pipeUnrollProcessorShard, workersCount),
|
shards: make([]pipeUnrollProcessorShard, workersCount),
|
||||||
|
@ -85,6 +86,7 @@ func (pu *pipeUnroll) newPipeProcessor(workersCount int, _ <-chan struct{}, _ fu
|
||||||
|
|
||||||
type pipeUnrollProcessor struct {
|
type pipeUnrollProcessor struct {
|
||||||
pu *pipeUnroll
|
pu *pipeUnroll
|
||||||
|
stopCh <-chan struct{}
|
||||||
ppNext pipeProcessor
|
ppNext pipeProcessor
|
||||||
|
|
||||||
shards []pipeUnrollProcessorShard
|
shards []pipeUnrollProcessorShard
|
||||||
|
@ -139,6 +141,9 @@ func (pup *pipeUnrollProcessor) writeBlock(workerID uint, br *blockResult) {
|
||||||
fields := shard.fields
|
fields := shard.fields
|
||||||
for rowIdx := range br.timestamps {
|
for rowIdx := range br.timestamps {
|
||||||
if bm.isSetBit(rowIdx) {
|
if bm.isSetBit(rowIdx) {
|
||||||
|
if needStop(pup.stopCh) {
|
||||||
|
return
|
||||||
|
}
|
||||||
shard.writeUnrolledFields(br, pu.fields, columnValues, rowIdx)
|
shard.writeUnrolledFields(br, pu.fields, columnValues, rowIdx)
|
||||||
} else {
|
} else {
|
||||||
fields = fields[:0]
|
fields = fields[:0]
|
||||||
|
|
Loading…
Reference in a new issue