mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-20 15:16:42 +00:00
wip
This commit is contained in:
parent
53c3384bf7
commit
fcbad5ac1b
3 changed files with 22 additions and 29 deletions
|
@ -1,7 +1,6 @@
|
||||||
package logstorage
|
package logstorage
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"slices"
|
|
||||||
"strconv"
|
"strconv"
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
@ -118,11 +117,10 @@ func (bs *blockSearch) search(bsw *blockSearchWork) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// fetch the requested columns to bs.br.
|
// fetch the requested columns to bs.br.
|
||||||
columnNames := bs.bsw.so.resultColumnNames
|
if bs.bsw.so.needAllColumns {
|
||||||
if slices.Contains(columnNames, "*") {
|
|
||||||
bs.br.fetchAllColumns(bs, bm)
|
bs.br.fetchAllColumns(bs, bm)
|
||||||
} else {
|
} else {
|
||||||
bs.br.fetchRequestedColumns(bs, bm, columnNames)
|
bs.br.fetchRequestedColumns(bs, bm)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -362,8 +360,8 @@ func (br *blockResult) fetchAllColumns(bs *blockSearch, bm *filterBitmap) {
|
||||||
br.columnNames = br.columnNamesBuf
|
br.columnNames = br.columnNamesBuf
|
||||||
}
|
}
|
||||||
|
|
||||||
func (br *blockResult) fetchRequestedColumns(bs *blockSearch, bm *filterBitmap, columnNames []string) {
|
func (br *blockResult) fetchRequestedColumns(bs *blockSearch, bm *filterBitmap) {
|
||||||
for _, columnName := range columnNames {
|
for _, columnName := range bs.bsw.so.resultColumnNames {
|
||||||
switch columnName {
|
switch columnName {
|
||||||
case "_stream":
|
case "_stream":
|
||||||
if !br.addStreamColumn(bs) {
|
if !br.addStreamColumn(bs) {
|
||||||
|
@ -387,7 +385,7 @@ func (br *blockResult) fetchRequestedColumns(bs *blockSearch, bm *filterBitmap,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
br.columnNames = columnNames
|
br.columnNames = bs.bsw.so.resultColumnNames
|
||||||
}
|
}
|
||||||
|
|
||||||
func (br *blockResult) RowsCount() int {
|
func (br *blockResult) RowsCount() int {
|
||||||
|
|
|
@ -353,12 +353,7 @@ func (spp *statsPipeProcessor) writeBlock(workerID uint, timestamps []int64, col
|
||||||
}
|
}
|
||||||
if len(byFields) == 1 {
|
if len(byFields) == 1 {
|
||||||
// Special case for grouping by a single column.
|
// Special case for grouping by a single column.
|
||||||
idx := getBlockColumnIndex(columns, byFields[0])
|
values := getValuesForBlockColumn(columns, byFields[0], len(timestamps))
|
||||||
if idx < 0 {
|
|
||||||
logger.Panicf("BUG: columnIdx must be positive")
|
|
||||||
}
|
|
||||||
values := columns[idx].Values
|
|
||||||
|
|
||||||
if isConstValue(values) {
|
if isConstValue(values) {
|
||||||
// Fast path for column with constant value.
|
// Fast path for column with constant value.
|
||||||
shard.keyBuf = encoding.MarshalBytes(shard.keyBuf[:0], bytesutil.ToUnsafeBytes(values[0]))
|
shard.keyBuf = encoding.MarshalBytes(shard.keyBuf[:0], bytesutil.ToUnsafeBytes(values[0]))
|
||||||
|
@ -385,7 +380,7 @@ func (spp *statsPipeProcessor) writeBlock(workerID uint, timestamps []int64, col
|
||||||
}
|
}
|
||||||
|
|
||||||
// Pre-calculate column values for byFields in order to speed up building group key in the loop below.
|
// Pre-calculate column values for byFields in order to speed up building group key in the loop below.
|
||||||
shard.columnValues = appendBlockColumnValues(shard.columnValues[:0], columns, spp.sp.byFields)
|
shard.columnValues = appendBlockColumnValues(shard.columnValues[:0], columns, spp.sp.byFields, len(timestamps))
|
||||||
columnValues := shard.columnValues
|
columnValues := shard.columnValues
|
||||||
|
|
||||||
if areConstValues(columnValues) {
|
if areConstValues(columnValues) {
|
||||||
|
@ -407,9 +402,6 @@ func (spp *statsPipeProcessor) writeBlock(workerID uint, timestamps []int64, col
|
||||||
// verify whether the key for 'by (...)' fields equals the previous key
|
// verify whether the key for 'by (...)' fields equals the previous key
|
||||||
sameValue := sfps != nil
|
sameValue := sfps != nil
|
||||||
for _, values := range columnValues {
|
for _, values := range columnValues {
|
||||||
if values == nil {
|
|
||||||
logger.Panicf("BUG: values cannot be nil here!")
|
|
||||||
}
|
|
||||||
if i <= 0 || values[i-1] != values[i] {
|
if i <= 0 || values[i-1] != values[i] {
|
||||||
sameValue = false
|
sameValue = false
|
||||||
break
|
break
|
||||||
|
@ -441,6 +433,7 @@ func areConstValues(valuess [][]string) bool {
|
||||||
|
|
||||||
func isConstValue(values []string) bool {
|
func isConstValue(values []string) bool {
|
||||||
if len(values) == 0 {
|
if len(values) == 0 {
|
||||||
|
// Return false, since it is impossible to get values[0] value from empty values.
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
vFirst := values[0]
|
vFirst := values[0]
|
||||||
|
@ -759,7 +752,7 @@ func (sfup *statsFuncUniqProcessor) updateStatsForAllRows(timestamps []int64, co
|
||||||
// Slow path for multiple columns.
|
// Slow path for multiple columns.
|
||||||
|
|
||||||
// Pre-calculate column values for byFields in order to speed up building group key in the loop below.
|
// Pre-calculate column values for byFields in order to speed up building group key in the loop below.
|
||||||
sfup.columnValues = appendBlockColumnValues(sfup.columnValues[:0], columns, fields)
|
sfup.columnValues = appendBlockColumnValues(sfup.columnValues[:0], columns, fields, len(timestamps))
|
||||||
columnValues := sfup.columnValues
|
columnValues := sfup.columnValues
|
||||||
|
|
||||||
keyBuf := sfup.keyBuf
|
keyBuf := sfup.keyBuf
|
||||||
|
@ -767,10 +760,7 @@ func (sfup *statsFuncUniqProcessor) updateStatsForAllRows(timestamps []int64, co
|
||||||
allEmptyValues := true
|
allEmptyValues := true
|
||||||
keyBuf = keyBuf[:0]
|
keyBuf = keyBuf[:0]
|
||||||
for _, values := range columnValues {
|
for _, values := range columnValues {
|
||||||
v := ""
|
v := values[i]
|
||||||
if values != nil {
|
|
||||||
v = values[i]
|
|
||||||
}
|
|
||||||
if v != "" {
|
if v != "" {
|
||||||
allEmptyValues = false
|
allEmptyValues = false
|
||||||
}
|
}
|
||||||
|
@ -1104,13 +1094,9 @@ func getFieldsIgnoreStar(fields []string) []string {
|
||||||
return result
|
return result
|
||||||
}
|
}
|
||||||
|
|
||||||
func appendBlockColumnValues(dst [][]string, columns []BlockColumn, fields []string) [][]string {
|
func appendBlockColumnValues(dst [][]string, columns []BlockColumn, fields []string, rowsCount int) [][]string {
|
||||||
for _, f := range fields {
|
for _, f := range fields {
|
||||||
idx := getBlockColumnIndex(columns, f)
|
values := getValuesForBlockColumn(columns, f, rowsCount)
|
||||||
var values []string
|
|
||||||
if idx >= 0 {
|
|
||||||
values = columns[idx].Values
|
|
||||||
}
|
|
||||||
dst = append(dst, values)
|
dst = append(dst, values)
|
||||||
}
|
}
|
||||||
return dst
|
return dst
|
||||||
|
|
|
@ -3,6 +3,7 @@ package logstorage
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"math"
|
"math"
|
||||||
|
"slices"
|
||||||
"sort"
|
"sort"
|
||||||
"sync"
|
"sync"
|
||||||
"sync/atomic"
|
"sync/atomic"
|
||||||
|
@ -18,8 +19,11 @@ type genericSearchOptions struct {
|
||||||
// filter is the filter to use for the search
|
// filter is the filter to use for the search
|
||||||
filter filter
|
filter filter
|
||||||
|
|
||||||
// resultColumnNames is names of columns to return in the result.
|
// resultColumnNames is names of columns to return in the result
|
||||||
resultColumnNames []string
|
resultColumnNames []string
|
||||||
|
|
||||||
|
// needAllColumns is set to true when all the columns must be returned in the result
|
||||||
|
needAllColumns bool
|
||||||
}
|
}
|
||||||
|
|
||||||
type searchOptions struct {
|
type searchOptions struct {
|
||||||
|
@ -42,6 +46,9 @@ type searchOptions struct {
|
||||||
|
|
||||||
// resultColumnNames is names of columns to return in the result
|
// resultColumnNames is names of columns to return in the result
|
||||||
resultColumnNames []string
|
resultColumnNames []string
|
||||||
|
|
||||||
|
// needAllColumns is set to true when all the columns must be returned in the result
|
||||||
|
needAllColumns bool
|
||||||
}
|
}
|
||||||
|
|
||||||
// RunQuery runs the given q and calls writeBlock for results.
|
// RunQuery runs the given q and calls writeBlock for results.
|
||||||
|
@ -51,6 +58,7 @@ func (s *Storage) RunQuery(ctx context.Context, tenantIDs []TenantID, q *Query,
|
||||||
tenantIDs: tenantIDs,
|
tenantIDs: tenantIDs,
|
||||||
filter: q.f,
|
filter: q.f,
|
||||||
resultColumnNames: resultColumnNames,
|
resultColumnNames: resultColumnNames,
|
||||||
|
needAllColumns: slices.Contains(resultColumnNames, "*"),
|
||||||
}
|
}
|
||||||
|
|
||||||
workersCount := cgroup.AvailableCPUs()
|
workersCount := cgroup.AvailableCPUs()
|
||||||
|
@ -316,6 +324,7 @@ func (pt *partition) search(tf *timeFilter, sf *StreamFilter, f filter, so *gene
|
||||||
maxTimestamp: tf.maxTimestamp,
|
maxTimestamp: tf.maxTimestamp,
|
||||||
filter: f,
|
filter: f,
|
||||||
resultColumnNames: so.resultColumnNames,
|
resultColumnNames: so.resultColumnNames,
|
||||||
|
needAllColumns: so.needAllColumns,
|
||||||
}
|
}
|
||||||
return pt.ddb.search(soInternal, workCh, stopCh)
|
return pt.ddb.search(soInternal, workCh, stopCh)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue