OpenBlock opens the block in the directory. It can be passed a chunk pool, which is used to instantiate chunk structs.
(logger *slog.Logger, dir string, pool chunkenc.Pool, postingsDecoderFactory PostingsDecoderFactory)
| 337 | // OpenBlock opens the block in the directory. It can be passed a chunk pool, which is used |
| 338 | // to instantiate chunk structs. |
| 339 | func OpenBlock(logger *slog.Logger, dir string, pool chunkenc.Pool, postingsDecoderFactory PostingsDecoderFactory) (pb *Block, err error) { |
| 340 | if logger == nil { |
| 341 | logger = promslog.NewNopLogger() |
| 342 | } |
| 343 | var closers []io.Closer |
| 344 | defer func() { |
| 345 | if err != nil { |
| 346 | err = errors.Join(err, closeAll(closers)) |
| 347 | } |
| 348 | }() |
| 349 | meta, sizeMeta, err := readMetaFile(dir) |
| 350 | if err != nil { |
| 351 | return nil, err |
| 352 | } |
| 353 | |
| 354 | cr, err := chunks.NewDirReader(chunkDir(dir), pool) |
| 355 | if err != nil { |
| 356 | return nil, err |
| 357 | } |
| 358 | closers = append(closers, cr) |
| 359 | |
| 360 | decoder := index.DecodePostingsRaw |
| 361 | if postingsDecoderFactory != nil { |
| 362 | decoder = postingsDecoderFactory(meta) |
| 363 | } |
| 364 | ir, err := index.NewFileReader(filepath.Join(dir, indexFilename), decoder) |
| 365 | if err != nil { |
| 366 | return nil, err |
| 367 | } |
| 368 | closers = append(closers, ir) |
| 369 | |
| 370 | tr, sizeTomb, err := tombstones.ReadTombstones(dir) |
| 371 | if err != nil { |
| 372 | return nil, err |
| 373 | } |
| 374 | closers = append(closers, tr) |
| 375 | |
| 376 | pb = &Block{ |
| 377 | dir: dir, |
| 378 | meta: *meta, |
| 379 | chunkr: cr, |
| 380 | indexr: ir, |
| 381 | tombstones: tr, |
| 382 | symbolTableSize: ir.SymbolTableSize(), |
| 383 | logger: logger, |
| 384 | numBytesChunks: cr.Size(), |
| 385 | numBytesIndex: ir.Size(), |
| 386 | numBytesTombstone: sizeTomb, |
| 387 | numBytesMeta: sizeMeta, |
| 388 | } |
| 389 | return pb, nil |
| 390 | } |
| 391 | |
| 392 | // Close closes the on-disk block. It blocks as long as there are readers reading from the block. |
| 393 | func (pb *Block) Close() error { |
searching dependent graphs…