Documentation ¶
Index ¶
- Constants
- Variables
- func NewTableClient(directory string) (chunk.TableClient, error)
- func OpenBoltdbFile(path string) (*bbolt.DB, error)
- type BoltDBConfig
- type BoltIndexClient
- func (b *BoltIndexClient) BatchWrite(ctx context.Context, batch chunk.WriteBatch) error
- func (b *BoltIndexClient) GetDB(name string, operation int) (*bbolt.DB, error)
- func (b *BoltIndexClient) NewWriteBatch() chunk.WriteBatch
- func (b *BoltIndexClient) QueryDB(ctx context.Context, db *bbolt.DB, query chunk.IndexQuery, ...) error
- func (b *BoltIndexClient) QueryPages(ctx context.Context, queries []chunk.IndexQuery, ...) error
- func (b *BoltIndexClient) Stop()
- type FSConfig
- type FSObjectClient
- func (f *FSObjectClient) DeleteChunksBefore(ctx context.Context, ts time.Time) error
- func (f *FSObjectClient) DeleteObject(ctx context.Context, objectKey string) error
- func (f *FSObjectClient) GetObject(ctx context.Context, objectKey string) (io.ReadCloser, error)
- func (f *FSObjectClient) List(ctx context.Context, prefix string) ([]chunk.StorageObject, error)
- func (f *FSObjectClient) PutObject(ctx context.Context, objectKey string, object io.ReadSeeker) error
- func (FSObjectClient) Stop()
Constants ¶
const ( DBOperationRead = iota DBOperationWrite )
Variables ¶
var (
ErrUnexistentBoltDB = errors.New("boltdb file does not exist")
)
var Fixtures = []testutils.Fixture{
&fixture{
name: "boltdb",
},
}
Fixtures for unit testing GCP storage.
Functions ¶
func NewTableClient ¶
func NewTableClient(directory string) (chunk.TableClient, error)
NewTableClient returns a new TableClient.
Types ¶
type BoltDBConfig ¶
type BoltDBConfig struct {
Directory string `yaml:"directory"`
}
BoltDBConfig for a BoltDB index client.
func (*BoltDBConfig) RegisterFlags ¶
func (cfg *BoltDBConfig) RegisterFlags(f *flag.FlagSet)
RegisterFlags registers flags.
type BoltIndexClient ¶ added in v0.7.0
type BoltIndexClient struct {
// contains filtered or unexported fields
}
func NewBoltDBIndexClient ¶
func NewBoltDBIndexClient(cfg BoltDBConfig) (*BoltIndexClient, error)
NewBoltDBIndexClient creates a new IndexClient that used BoltDB.
func (*BoltIndexClient) BatchWrite ¶ added in v0.7.0
func (b *BoltIndexClient) BatchWrite(ctx context.Context, batch chunk.WriteBatch) error
func (*BoltIndexClient) GetDB ¶ added in v0.7.0
GetDB should always return a db for write operation unless an error occurs while doing so. While for read operation it should throw ErrUnexistentBoltDB error if file does not exist for reading
func (*BoltIndexClient) NewWriteBatch ¶ added in v0.7.0
func (b *BoltIndexClient) NewWriteBatch() chunk.WriteBatch
func (*BoltIndexClient) QueryPages ¶ added in v0.7.0
func (b *BoltIndexClient) QueryPages(ctx context.Context, queries []chunk.IndexQuery, callback func(chunk.IndexQuery, chunk.ReadBatch) (shouldContinue bool)) error
func (*BoltIndexClient) Stop ¶ added in v0.7.0
func (b *BoltIndexClient) Stop()
type FSConfig ¶
type FSConfig struct {
Directory string `yaml:"directory"`
}
FSConfig is the config for a FSObjectClient.
func (*FSConfig) RegisterFlags ¶
RegisterFlags registers flags.
type FSObjectClient ¶
type FSObjectClient struct {
// contains filtered or unexported fields
}
FSObjectClient holds config for filesystem as object store
func NewFSObjectClient ¶
func NewFSObjectClient(cfg FSConfig) (*FSObjectClient, error)
NewFSObjectClient makes a chunk.Client which stores chunks as files in the local filesystem.
func (*FSObjectClient) DeleteChunksBefore ¶
DeleteChunksBefore implements BucketClient
func (*FSObjectClient) DeleteObject ¶ added in v0.7.0
func (f *FSObjectClient) DeleteObject(ctx context.Context, objectKey string) error
func (*FSObjectClient) GetObject ¶ added in v0.7.0
func (f *FSObjectClient) GetObject(ctx context.Context, objectKey string) (io.ReadCloser, error)
GetObject from the store
func (*FSObjectClient) List ¶ added in v0.7.0
func (f *FSObjectClient) List(ctx context.Context, prefix string) ([]chunk.StorageObject, error)
List only objects from the store non-recursively
func (*FSObjectClient) PutObject ¶ added in v0.7.0
func (f *FSObjectClient) PutObject(ctx context.Context, objectKey string, object io.ReadSeeker) error
PutObject into the store