Like Prometheus, but for logs.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
loki/pkg/storage/chunk/factory.go

115 lines
2.4 KiB

package chunk
import (
"flag"
"fmt"
"strconv"
)
// Encoding defines which encoding we are using, delta, doubledelta, or varbit
type Encoding byte
// Config configures the behaviour of chunk encoding
type Config struct{}
var (
// DefaultEncoding exported for use in unit tests elsewhere
DefaultEncoding = Bigchunk
bigchunkSizeCapBytes = 0
)
// RegisterFlags registers configuration settings.
func (Config) RegisterFlags(f *flag.FlagSet) {
f.Var(&DefaultEncoding, "ingester.chunk-encoding", "Encoding version to use for chunks.")
f.IntVar(&bigchunkSizeCapBytes, "store.bigchunk-size-cap-bytes", bigchunkSizeCapBytes, "When using bigchunk encoding, start a new bigchunk if over this size (0 = unlimited)")
}
// Validate errors out if the encoding is set to Delta.
func (Config) Validate() error {
return nil
}
// String implements flag.Value.
func (e Encoding) String() string {
if known, found := encodings[e]; found {
return known.Name
}
return fmt.Sprintf("%d", e)
}
const (
// Big chunk encoding.
Bigchunk Encoding = iota
)
type encoding struct {
Name string
New func() Data
}
var encodings = map[Encoding]encoding{
Bigchunk: {
Name: "Bigchunk",
New: func() Data {
return newBigchunk()
},
},
}
// Set implements flag.Value.
func (e *Encoding) Set(s string) error {
// First see if the name was given
for k, v := range encodings {
if s == v.Name {
*e = k
return nil
}
}
// Otherwise, accept a number
i, err := strconv.Atoi(s)
if err != nil {
return err
}
_, ok := encodings[Encoding(i)]
if !ok {
return fmt.Errorf("invalid chunk encoding: %s", s)
}
*e = Encoding(i)
return nil
}
// New creates a new chunk according to the encoding set by the
// DefaultEncoding flag.
func New() Data {
chunk, err := NewForEncoding(DefaultEncoding)
if err != nil {
panic(err)
}
return chunk
}
// NewForEncoding allows configuring what chunk type you want
func NewForEncoding(encoding Encoding) (Data, error) {
enc, ok := encodings[encoding]
if !ok {
return nil, fmt.Errorf("unknown chunk encoding: %v", encoding)
}
return enc.New(), nil
}
// MustRegisterEncoding add a new chunk encoding. There is no locking, so this
// must be called in init().
func MustRegisterEncoding(enc Encoding, name string, f func() Data) {
_, ok := encodings[enc]
if ok {
panic("double register encoding")
}
encodings[enc] = encoding{
Name: name,
New: f,
}
}