Documentation ¶
Index ¶
- Constants
- Variables
- func DeleteIndex(ctx context.Context, bkt objstore.Bucket, userID string, ...) error
- func WriteIndex(ctx context.Context, bkt objstore.Bucket, userID string, ...) error
- type Block
- type BlockDeletionMark
- type BlockDeletionMarks
- type Blocks
- type Index
- type Loader
- type LoaderConfig
- type Updater
Constants ¶
const ( IndexFilename = "bucket-index.json" IndexCompressedFilename = IndexFilename + ".gz" IndexVersion1 = 1 IndexVersion2 = 2 // Added CompactorShardID field. IndexVersion3 = 3 // Added CompactionLevel field. )
Variables ¶
var ( ErrIndexNotFound = errors.New("bucket index not found") ErrIndexCorrupted = errors.New("bucket index corrupted") )
var ( ErrBlockMetaNotFound = block.ErrorSyncMetaNotFound ErrBlockMetaCorrupted = block.ErrorSyncMetaCorrupted ErrBlockDeletionMarkNotFound = errors.New("block deletion mark not found") ErrBlockDeletionMarkCorrupted = errors.New("block deletion mark corrupted") )
Functions ¶
func DeleteIndex ¶
func DeleteIndex(ctx context.Context, bkt objstore.Bucket, userID string, cfgProvider objstore.TenantConfigProvider) error
DeleteIndex deletes the bucket index from the storage. No error is returned if the index does not exist.
Types ¶
type Block ¶
type Block struct { // Block ID. ID ulid.ULID `json:"block_id"` // MinTime and MaxTime specify the time range all samples in the block are in (millis precision). MinTime model.Time `json:"min_time"` MaxTime model.Time `json:"max_time"` // UploadedAt is a unix timestamp (seconds precision) of when the block has been completed to be uploaded // to the storage. UploadedAt int64 `json:"uploaded_at"` // Block's compactor shard ID, copied from tsdb.CompactorShardIDExternalLabel label. CompactorShardID string `json:"compactor_shard_id,omitempty"` CompactionLevel int `json:"compaction_level,omitempty"` }
Block holds the information about a block in the index.
func BlockFromMeta ¶
func (*Block) GetUploadedAt ¶
type BlockDeletionMark ¶
type BlockDeletionMark struct { // Block ID. ID ulid.ULID `json:"block_id"` // DeletionTime is a unix timestamp (seconds precision) of when the block was marked to be deleted. DeletionTime int64 `json:"deletion_time"` }
BlockDeletionMark holds the information about a block's deletion mark in the index.
func DeletionMarkFromBlockMarker ¶
func DeletionMarkFromBlockMarker(mark *block.DeletionMark) *BlockDeletionMark
func (*BlockDeletionMark) BlockDeletionMark ¶
func (m *BlockDeletionMark) BlockDeletionMark() *block.DeletionMark
BlockDeletionMark returns the block deletion mark.
func (*BlockDeletionMark) GetDeletionTime ¶
func (m *BlockDeletionMark) GetDeletionTime() time.Time
type BlockDeletionMarks ¶
type BlockDeletionMarks []*BlockDeletionMark
BlockDeletionMarks holds a set of block deletion marks in the index. No ordering guaranteed.
func (BlockDeletionMarks) Clone ¶
func (s BlockDeletionMarks) Clone() BlockDeletionMarks
func (BlockDeletionMarks) GetULIDs ¶
func (s BlockDeletionMarks) GetULIDs() []ulid.ULID
type Blocks ¶
type Blocks []*Block
Blocks holds a set of blocks in the index. No ordering guaranteed.
type Index ¶
type Index struct { // Version of the index format. Version int `json:"version"` // List of complete blocks (partial blocks are excluded from the index). Blocks Blocks `json:"blocks"` // List of block deletion marks. BlockDeletionMarks BlockDeletionMarks `json:"block_deletion_marks"` // UpdatedAt is a unix timestamp (seconds precision) of when the index has been updated // (written in the storage) the last time. UpdatedAt int64 `json:"updated_at"` }
Index contains all known blocks and markers of a tenant.
func ReadIndex ¶
func ReadIndex(ctx context.Context, bkt objstore.Bucket, userID string, cfgProvider objstore.TenantConfigProvider, logger log.Logger) (*Index, error)
ReadIndex reads, parses and returns a bucket index from the bucket. ReadIndex has a one-minute timeout for completing the read against the bucket. One minute is hard-coded to a reasonably high value to protect against operations that can take unbounded time.
func (*Index) GetUpdatedAt ¶
func (*Index) RemoveBlock ¶
RemoveBlock removes block and its deletion mark (if any) from index.
type Loader ¶
Loader is responsible to lazy load bucket indexes and, once loaded for the first time, keep them updated in background. Loaded indexes are automatically offloaded once the idle timeout expires.
func NewLoader ¶
func NewLoader(cfg LoaderConfig, bucketClient objstore.Bucket, cfgProvider objstore.TenantConfigProvider, logger log.Logger, reg prometheus.Registerer) *Loader
NewLoader makes a new Loader.
type LoaderConfig ¶
type Updater ¶
type Updater struct {
// contains filtered or unexported fields
}
Updater is responsible to generate an update in-memory bucket index.
func NewUpdater ¶
func (*Updater) UpdateIndex ¶
UpdateIndex generates the bucket index and returns it, without storing it to the storage. If the old index is not passed in input, then the bucket index will be generated from scratch.