Documentation ¶
Overview ¶
Package inmem implements a shared, in-memory index for each database.
The in-memory index is the original index implementation and provides fast access to index data. However, it also forces high memory usage for large datasets and can cause OOM errors.
Index is the shared index structure that provides most of the functionality. However, ShardIndex is a light per-shard wrapper that adapts this original shared index format to the new per-shard format.
Index ¶
- Constants
- func NewShardIndex(id uint64, database, path string, seriesIDSet *tsdb.SeriesIDSet, ...) tsdb.Index
- type FilterExprs
- type Index
- func (i *Index) Close() error
- func (i *Index) CreateMeasurementIndexIfNotExists(name []byte) *measurement
- func (i *Index) CreateSeriesListIfNotExists(shardID uint64, seriesIDSet *tsdb.SeriesIDSet, keys, names [][]byte, ...) error
- func (i *Index) Database() string
- func (i *Index) DiskSizeBytes() int64
- func (i *Index) DropMeasurement(name []byte) error
- func (i *Index) DropMeasurementIfSeriesNotExist(name []byte) error
- func (i *Index) DropSeriesGlobal(key []byte, ts int64) error
- func (i *Index) FieldSet() *tsdb.MeasurementFieldSet
- func (i *Index) ForEachMeasurementName(fn func(name []byte) error) error
- func (i *Index) ForEachMeasurementTagKey(name []byte, fn func(key []byte) error) error
- func (i *Index) HasTagKey(name, key []byte) (bool, error)
- func (i *Index) HasTagValue(name, key, value []byte) (bool, error)
- func (i *Index) Measurement(name []byte) (*measurement, error)
- func (i *Index) MeasurementExists(name []byte) (bool, error)
- func (i *Index) MeasurementIterator() (tsdb.MeasurementIterator, error)
- func (i *Index) MeasurementNamesByExpr(auth query.Authorizer, expr influxql.Expr) ([][]byte, error)
- func (i *Index) MeasurementNamesByRegex(re *regexp.Regexp) ([][]byte, error)
- func (i *Index) MeasurementSeriesIDIterator(name []byte) (tsdb.SeriesIDIterator, error)
- func (i *Index) MeasurementSeriesKeysByExpr(name []byte, condition influxql.Expr) ([][]byte, error)
- func (i *Index) MeasurementSeriesKeysByExprIterator(name []byte, condition influxql.Expr) (tsdb.SeriesIDIterator, error)
- func (i *Index) MeasurementTagKeyValuesByExpr(auth query.Authorizer, name []byte, keys []string, expr influxql.Expr, ...) ([][]string, error)
- func (i *Index) MeasurementTagKeysByExpr(name []byte, expr influxql.Expr) (map[string]struct{}, error)
- func (i *Index) MeasurementsByName(names [][]byte) ([]*measurement, error)
- func (i *Index) MeasurementsSketches() (estimator.Sketch, estimator.Sketch, error)
- func (i *Index) Open() (err error)
- func (i *Index) Rebuild()
- func (i *Index) Series(key []byte) (*series, error)
- func (i *Index) SeriesIDIterator(opt query.IteratorOptions) (tsdb.SeriesIDIterator, error)
- func (i *Index) SeriesKeys() []string
- func (i *Index) SeriesSketches() (estimator.Sketch, estimator.Sketch, error)
- func (i *Index) SetFieldName(measurement []byte, name string)
- func (i *Index) SetFieldSet(fieldset *tsdb.MeasurementFieldSet)
- func (i *Index) TagKeyCardinality(name, key []byte) int
- func (i *Index) TagKeyHasAuthorizedSeries(auth query.Authorizer, name []byte, key string) bool
- func (i *Index) TagKeyIterator(name []byte) (tsdb.TagKeyIterator, error)
- func (i *Index) TagKeySeriesIDIterator(name, key []byte) (tsdb.SeriesIDIterator, error)
- func (i *Index) TagSets(shardID uint64, name []byte, opt query.IteratorOptions) ([]*query.TagSet, error)
- func (i *Index) TagValueIterator(name, key []byte) (tsdb.TagValueIterator, error)
- func (i *Index) TagValueN(name, key []byte) int
- func (i *Index) TagValueSeriesIDIterator(name, key, value []byte) (tsdb.SeriesIDIterator, error)
- func (i *Index) TagsForSeries(key string) (models.Tags, error)
- func (i *Index) Type() string
- func (i *Index) WithLogger(*zap.Logger)
- type ShardIndex
- func (idx *ShardIndex) CreateSeriesIfNotExists(key, name []byte, tags models.Tags) error
- func (idx *ShardIndex) CreateSeriesListIfNotExists(keys, names [][]byte, tagsSlice []models.Tags) error
- func (idx *ShardIndex) DropMeasurementIfSeriesNotExist(name []byte) error
- func (idx *ShardIndex) DropSeries(seriesID uint64, _ []byte, _ bool) error
- func (idx *ShardIndex) InitializeSeries(key, name []byte, tags models.Tags) error
- func (idx *ShardIndex) SeriesIDSet() *tsdb.SeriesIDSet
- func (idx *ShardIndex) SeriesN() int64
- func (idx *ShardIndex) TagSets(name []byte, opt query.IteratorOptions) ([]*query.TagSet, error)
- type TagFilter
Constants ¶
const IndexName = "inmem"
IndexName is the name of this index.
Variables ¶
This section is empty.
Functions ¶
func NewShardIndex ¶
func NewShardIndex(id uint64, database, path string, seriesIDSet *tsdb.SeriesIDSet, sfile *tsdb.SeriesFile, opt tsdb.EngineOptions) tsdb.Index
NewShardIndex returns a new index for a shard.
Types ¶
type FilterExprs ¶
FilterExprs represents a map of series IDs to filter expressions.
func (FilterExprs) DeleteBoolLiteralTrues ¶
func (fe FilterExprs) DeleteBoolLiteralTrues()
DeleteBoolLiteralTrues deletes all elements whose filter expression is a boolean literal true.
type Index ¶
type Index struct {
// contains filtered or unexported fields
}
Index is the in memory index of a collection of measurements, time series, and their tags. Exported functions are goroutine safe while un-exported functions assume the caller will use the appropriate locks.
func NewIndex ¶
func NewIndex(database string, sfile *tsdb.SeriesFile) *Index
NewIndex returns a new initialized Index.
func (*Index) CreateMeasurementIndexIfNotExists ¶
CreateMeasurementIndexIfNotExists creates or retrieves an in memory index object for the measurement
func (*Index) CreateSeriesListIfNotExists ¶
func (i *Index) CreateSeriesListIfNotExists(shardID uint64, seriesIDSet *tsdb.SeriesIDSet, keys, names [][]byte, tagsSlice []models.Tags, opt *tsdb.EngineOptions, ignoreLimits bool) error
CreateSeriesListIfNotExists adds the series for the given measurement to the index and sets its ID or returns the existing series object
func (*Index) DiskSizeBytes ¶
DiskSizeBytes always returns zero bytes, since this is an in-memory index.
func (*Index) DropMeasurement ¶
DropMeasurement removes the measurement and all of its underlying series from the database index
func (*Index) DropMeasurementIfSeriesNotExist ¶
DropMeasurementIfSeriesNotExist drops a measurement only if there are no more series for the measurment.
func (*Index) DropSeriesGlobal ¶
DropSeriesGlobal removes the series key and its tags from the index.
func (*Index) FieldSet ¶
func (i *Index) FieldSet() *tsdb.MeasurementFieldSet
FieldSet returns the assigned fieldset.
func (*Index) ForEachMeasurementName ¶
ForEachMeasurementName iterates over each measurement name.
func (*Index) ForEachMeasurementTagKey ¶
ForEachMeasurementTagKey iterates over all tag keys for a measurement.
func (*Index) HasTagValue ¶
HasTagValue returns true if tag value exists.
func (*Index) Measurement ¶
Measurement returns the measurement object from the index by the name
func (*Index) MeasurementExists ¶
MeasurementExists returns true if the measurement exists.
func (*Index) MeasurementIterator ¶
func (i *Index) MeasurementIterator() (tsdb.MeasurementIterator, error)
MeasurementIterator returns an iterator over all measurements in the index. MeasurementIterator does not support authorization.
func (*Index) MeasurementNamesByExpr ¶
MeasurementNamesByExpr takes an expression containing only tags and returns a list of matching measurement names.
TODO(edd): Remove authorisation from these methods. There shouldn't need to be any auth passed down into the index.
func (*Index) MeasurementNamesByRegex ¶
MeasurementNamesByRegex returns the measurements that match the regex.
func (*Index) MeasurementSeriesIDIterator ¶
func (i *Index) MeasurementSeriesIDIterator(name []byte) (tsdb.SeriesIDIterator, error)
func (*Index) MeasurementSeriesKeysByExpr ¶
func (*Index) MeasurementSeriesKeysByExprIterator ¶
func (*Index) MeasurementTagKeyValuesByExpr ¶
func (i *Index) MeasurementTagKeyValuesByExpr(auth query.Authorizer, name []byte, keys []string, expr influxql.Expr, keysSorted bool) ([][]string, error)
MeasurementTagKeyValuesByExpr returns a set of tag values filtered by an expression.
See tsm1.Engine.MeasurementTagKeyValuesByExpr for a fuller description of this method.
func (*Index) MeasurementTagKeysByExpr ¶
func (i *Index) MeasurementTagKeysByExpr(name []byte, expr influxql.Expr) (map[string]struct{}, error)
MeasurementTagKeysByExpr returns an ordered set of tag keys filtered by an expression.
func (*Index) MeasurementsByName ¶
MeasurementsByName returns a list of measurements.
func (*Index) MeasurementsSketches ¶
MeasurementsSketches returns the sketches for the measurements.
func (*Index) Rebuild ¶
func (i *Index) Rebuild()
Rebuild recreates the measurement indexes to allow deleted series to be removed and garbage collected.
func (*Index) SeriesIDIterator ¶
func (i *Index) SeriesIDIterator(opt query.IteratorOptions) (tsdb.SeriesIDIterator, error)
SeriesIDIterator returns an influxql iterator over matching series ids.
func (*Index) SeriesKeys ¶
func (*Index) SeriesSketches ¶
SeriesSketches returns the sketches for the series.
func (*Index) SetFieldName ¶
SetFieldName adds a field name to a measurement.
func (*Index) SetFieldSet ¶
func (i *Index) SetFieldSet(fieldset *tsdb.MeasurementFieldSet)
SetFieldSet sets a shared field set from the engine.
func (*Index) TagKeyCardinality ¶
TagKeyCardinality returns the number of values for a measurement/tag key.
func (*Index) TagKeyHasAuthorizedSeries ¶
TagKeyHasAuthorizedSeries determines if there exists an authorized series for the provided measurement name and tag key.
func (*Index) TagKeyIterator ¶
func (i *Index) TagKeyIterator(name []byte) (tsdb.TagKeyIterator, error)
func (*Index) TagKeySeriesIDIterator ¶
func (i *Index) TagKeySeriesIDIterator(name, key []byte) (tsdb.SeriesIDIterator, error)
func (*Index) TagSets ¶
func (i *Index) TagSets(shardID uint64, name []byte, opt query.IteratorOptions) ([]*query.TagSet, error)
TagSets returns a list of tag sets.
func (*Index) TagValueIterator ¶
func (i *Index) TagValueIterator(name, key []byte) (tsdb.TagValueIterator, error)
TagValueIterator provides an iterator over all the tag values belonging to series with the provided measurement name and tag key.
TagValueIterator does not currently support authorization.
func (*Index) TagValueSeriesIDIterator ¶
func (i *Index) TagValueSeriesIDIterator(name, key, value []byte) (tsdb.SeriesIDIterator, error)
func (*Index) TagsForSeries ¶
TagsForSeries returns the tag map for the passed in series
func (*Index) WithLogger ¶
type ShardIndex ¶
type ShardIndex struct { *Index // Shared reference to global database-wide index. // contains filtered or unexported fields }
ShardIndex represents a shim between the TSDB index interface and the shared in-memory index. This is required because per-shard in-memory indexes will grow the heap size too large.
func (*ShardIndex) CreateSeriesIfNotExists ¶
func (idx *ShardIndex) CreateSeriesIfNotExists(key, name []byte, tags models.Tags) error
CreateSeriesIfNotExists creates the provided series on the index if it is not already present.
func (*ShardIndex) CreateSeriesListIfNotExists ¶
func (idx *ShardIndex) CreateSeriesListIfNotExists(keys, names [][]byte, tagsSlice []models.Tags) error
CreateSeriesListIfNotExists creates a list of series if they doesn't exist in bulk.
func (*ShardIndex) DropMeasurementIfSeriesNotExist ¶
func (idx *ShardIndex) DropMeasurementIfSeriesNotExist(name []byte) error
DropMeasurementIfSeriesNotExist drops a measurement only if there are no more series for the measurment.
func (*ShardIndex) DropSeries ¶
func (idx *ShardIndex) DropSeries(seriesID uint64, _ []byte, _ bool) error
DropSeries removes the provided series id from the local bitset that tracks series in this shard only.
func (*ShardIndex) InitializeSeries ¶
func (idx *ShardIndex) InitializeSeries(key, name []byte, tags models.Tags) error
InitializeSeries is called during start-up. This works the same as CreateSeriesIfNotExists except it ignore limit errors.
func (*ShardIndex) SeriesIDSet ¶
func (idx *ShardIndex) SeriesIDSet() *tsdb.SeriesIDSet
SeriesIDSet returns the bitset associated with the series ids.
func (*ShardIndex) SeriesN ¶
func (idx *ShardIndex) SeriesN() int64
SeriesN returns the number of unique non-tombstoned series local to this shard.
func (*ShardIndex) TagSets ¶
func (idx *ShardIndex) TagSets(name []byte, opt query.IteratorOptions) ([]*query.TagSet, error)
TagSets returns a list of tag sets based on series filtering.