influxdb/tsdb/engine.go

141 lines
3.9 KiB
Go
Raw Normal View History

2015-07-22 14:53:20 +00:00
package tsdb
import (
"errors"
"fmt"
"io"
"os"
"regexp"
"sort"
2015-07-22 14:53:20 +00:00
"time"
"github.com/influxdata/influxdb/influxql"
"github.com/influxdata/influxdb/models"
2016-09-21 15:04:37 +00:00
"github.com/influxdata/influxdb/pkg/estimator"
"go.uber.org/zap"
2015-07-22 14:53:20 +00:00
)
var (
// ErrFormatNotFound is returned when no format can be determined from a path.
ErrFormatNotFound = errors.New("format not found")
// ErrUnknownEngineFormat is returned when the engine format is
// unknown. ErrUnknownEngineFormat is currently returned if a format
// other than tsm1 is encountered.
ErrUnknownEngineFormat = errors.New("unknown engine format")
2015-07-22 14:53:20 +00:00
)
// Engine represents a swappable storage engine for the shard.
type Engine interface {
Open() error
Close() error
2016-09-14 13:55:44 +00:00
SetEnabled(enabled bool)
WithLogger(zap.Logger)
2016-09-14 13:55:44 +00:00
LoadMetadataIndex(shardID uint64, index *DatabaseIndex) error
2015-07-22 14:53:20 +00:00
2016-09-14 13:55:44 +00:00
CreateSnapshot() (string, error)
2016-04-29 00:29:09 +00:00
Backup(w io.Writer, basePath string, since time.Time) error
Restore(r io.Reader, basePath string) error
2015-11-04 21:06:06 +00:00
CreateIterator(opt influxql.IteratorOptions) (influxql.Iterator, error)
WritePoints(points []models.Point) error
CreateSeries(measurment string, series *Series) (*Series, error)
2016-09-29 09:39:13 +00:00
DeleteSeriesRange(keys [][]byte, min, max int64) error
Series(key []byte) (*Series, error)
2016-09-21 15:04:37 +00:00
SeriesN() (uint64, error)
2016-09-23 13:33:47 +00:00
SeriesSketches() (estimator.Sketch, estimator.Sketch, error)
MeasurementsSketches() (estimator.Sketch, estimator.Sketch, error)
CreateMeasurement(name string) (*Measurement, error)
2016-09-29 09:39:13 +00:00
DeleteMeasurement(name []byte, seriesKeys [][]byte) error
Measurement(name []byte) (*Measurement, error)
Measurements() (Measurements, error)
MeasurementsByExpr(expr influxql.Expr) (Measurements, bool, error)
MeasurementsByRegex(re *regexp.Regexp) (Measurements, error)
MeasurementFields(measurement string) *MeasurementFields
// Statistics will return statistics relevant to this engine.
Statistics(tags map[string]string) []models.Statistic
LastModified() time.Time
io.WriterTo
2015-07-22 14:53:20 +00:00
}
2016-02-10 20:04:18 +00:00
// EngineFormat represents the format for an engine.
type EngineFormat int
const (
2016-02-10 20:04:18 +00:00
// TSM1Format is the format used by the tsm1 engine.
2015-11-04 21:06:06 +00:00
TSM1Format EngineFormat = 2
)
2015-07-22 14:53:20 +00:00
// NewEngineFunc creates a new engine.
type NewEngineFunc func(id uint64, path string, walPath string, options EngineOptions) Engine
2015-07-22 14:53:20 +00:00
// newEngineFuncs is a lookup of engine constructors by name.
var newEngineFuncs = make(map[string]NewEngineFunc)
// RegisterEngine registers a storage engine initializer by name.
func RegisterEngine(name string, fn NewEngineFunc) {
if _, ok := newEngineFuncs[name]; ok {
panic("engine already registered: " + name)
}
newEngineFuncs[name] = fn
}
// RegisteredEngines returns the slice of currently registered engines.
func RegisteredEngines() []string {
a := make([]string, 0, len(newEngineFuncs))
2016-02-10 20:04:18 +00:00
for k := range newEngineFuncs {
a = append(a, k)
}
sort.Strings(a)
return a
}
2015-07-22 14:53:20 +00:00
// NewEngine returns an instance of an engine based on its format.
// If the path does not exist then the DefaultFormat is used.
func NewEngine(id uint64, path string, walPath string, options EngineOptions) (Engine, error) {
2015-07-22 14:53:20 +00:00
// Create a new engine
if _, err := os.Stat(path); os.IsNotExist(err) {
return newEngineFuncs[options.EngineVersion](id, path, walPath, options), nil
2015-07-22 14:53:20 +00:00
}
2015-11-04 21:06:06 +00:00
// If it's a dir then it's a tsm1 engine
format := DefaultEngine
2015-11-04 21:06:06 +00:00
if fi, err := os.Stat(path); err != nil {
2015-07-22 14:53:20 +00:00
return nil, err
2015-11-04 21:06:06 +00:00
} else if !fi.Mode().IsDir() {
return nil, ErrUnknownEngineFormat
2015-11-04 21:06:06 +00:00
} else {
format = "tsm1"
2015-07-22 14:53:20 +00:00
}
// Lookup engine by format.
fn := newEngineFuncs[format]
if fn == nil {
return nil, fmt.Errorf("invalid engine format: %q", format)
}
return fn(id, path, walPath, options), nil
2015-07-22 14:53:20 +00:00
}
// EngineOptions represents the options used to initialize the engine.
type EngineOptions struct {
EngineVersion string
ShardID uint64
2015-08-18 20:59:54 +00:00
Config Config
2015-07-22 14:53:20 +00:00
}
// NewEngineOptions returns the default options.
func NewEngineOptions() EngineOptions {
return EngineOptions{
EngineVersion: DefaultEngine,
Config: NewConfig(),
2015-07-22 14:53:20 +00:00
}
}