influxdb/storage/reads/array_cursor.go

145 lines
3.9 KiB
Go
Raw Normal View History

package reads
import (
"context"
"fmt"
"github.com/influxdata/flux/interval"
"github.com/influxdata/influxdb/v2/storage/reads/datatypes"
2020-08-26 17:46:47 +00:00
"github.com/influxdata/influxdb/v2/tsdb/cursors"
)
type singleValue struct {
v interface{}
}
func (v *singleValue) Value(key string) (interface{}, bool) {
return v.v, true
}
func newAggregateArrayCursor(ctx context.Context, agg *datatypes.Aggregate, cursor cursors.Cursor) (cursors.Cursor, error) {
2020-10-23 19:14:03 +00:00
switch agg.Type {
case datatypes.AggregateTypeFirst, datatypes.AggregateTypeLast:
return newLimitArrayCursor(cursor), nil
}
return newWindowAggregateArrayCursor(ctx, agg, interval.Window{}, cursor)
}
func newWindowAggregateArrayCursor(ctx context.Context, agg *datatypes.Aggregate, window interval.Window, cursor cursors.Cursor) (cursors.Cursor, error) {
if cursor == nil {
return nil, nil
}
2020-10-23 19:14:03 +00:00
switch agg.Type {
2020-04-24 16:47:22 +00:00
case datatypes.AggregateTypeCount:
2020-10-23 19:14:03 +00:00
return newWindowCountArrayCursor(cursor, window), nil
case datatypes.AggregateTypeSum:
return newWindowSumArrayCursor(cursor, window)
case datatypes.AggregateTypeFirst:
return newWindowFirstArrayCursor(cursor, window), nil
case datatypes.AggregateTypeLast:
return newWindowLastArrayCursor(cursor, window), nil
case datatypes.AggregateTypeMin:
return newWindowMinArrayCursor(cursor, window), nil
case datatypes.AggregateTypeMax:
return newWindowMaxArrayCursor(cursor, window), nil
case datatypes.AggregateTypeMean:
return newWindowMeanArrayCursor(cursor, window)
default:
// TODO(sgc): should be validated higher up
panic("invalid aggregate")
}
}
type cursorContext struct {
2020-10-23 19:14:03 +00:00
ctx context.Context
req *cursors.CursorRequest
itrs cursors.CursorIterators
err error
}
2020-04-24 16:47:22 +00:00
type multiShardArrayCursors struct {
2020-10-23 19:14:03 +00:00
ctx context.Context
req cursors.CursorRequest
cursors struct {
2020-04-24 16:47:22 +00:00
i integerMultiShardArrayCursor
f floatMultiShardArrayCursor
u unsignedMultiShardArrayCursor
b booleanMultiShardArrayCursor
s stringMultiShardArrayCursor
}
}
// newMultiShardArrayCursors is a factory for creating cursors for each series key.
// The range of the cursor is [start, end). The start time is the lower absolute time
// and the end time is the higher absolute time regardless of ascending or descending order.
2020-10-23 19:14:03 +00:00
func newMultiShardArrayCursors(ctx context.Context, start, end int64, asc bool) *multiShardArrayCursors {
// When we construct the CursorRequest, we translate the time range
// from [start, stop) to [start, stop]. The cursor readers from storage are
// inclusive on both ends and we perform that conversion here.
2020-04-24 16:47:22 +00:00
m := &multiShardArrayCursors{
2020-10-23 19:14:03 +00:00
ctx: ctx,
req: cursors.CursorRequest{
Ascending: asc,
StartTime: start,
EndTime: end - 1,
},
}
cc := cursorContext{
2020-10-23 19:14:03 +00:00
ctx: ctx,
req: &m.req,
}
m.cursors.i.cursorContext = cc
m.cursors.f.cursorContext = cc
m.cursors.u.cursorContext = cc
m.cursors.b.cursorContext = cc
m.cursors.s.cursorContext = cc
return m
}
2020-04-24 16:47:22 +00:00
func (m *multiShardArrayCursors) createCursor(row SeriesRow) cursors.Cursor {
m.req.Name = row.Name
m.req.Tags = row.SeriesTags
m.req.Field = row.Field
var cond expression
2020-04-24 16:47:22 +00:00
if row.ValueCond != nil {
cond = &astExpr{row.ValueCond}
}
2020-04-24 16:47:22 +00:00
var shard cursors.CursorIterator
var cur cursors.Cursor
for cur == nil && len(row.Query) > 0 {
shard, row.Query = row.Query[0], row.Query[1:]
cur, _ = shard.Next(m.ctx, &m.req)
}
2020-04-24 16:47:22 +00:00
if cur == nil {
return nil
}
switch c := cur.(type) {
case cursors.IntegerArrayCursor:
2020-04-24 16:47:22 +00:00
m.cursors.i.reset(c, row.Query, cond)
return &m.cursors.i
case cursors.FloatArrayCursor:
2020-04-24 16:47:22 +00:00
m.cursors.f.reset(c, row.Query, cond)
return &m.cursors.f
case cursors.UnsignedArrayCursor:
2020-04-24 16:47:22 +00:00
m.cursors.u.reset(c, row.Query, cond)
return &m.cursors.u
case cursors.StringArrayCursor:
2020-04-24 16:47:22 +00:00
m.cursors.s.reset(c, row.Query, cond)
return &m.cursors.s
case cursors.BooleanArrayCursor:
2020-04-24 16:47:22 +00:00
m.cursors.b.reset(c, row.Query, cond)
return &m.cursors.b
default:
panic(fmt.Sprintf("unreachable: %T", cur))
}
}