Always include empty symbol in the symbol table.

This commit is contained in:
Peter Štibraný 2021-10-06 10:17:16 +02:00
parent 9a50267ea5
commit d116268e59
2 changed files with 12 additions and 8 deletions

View file

@ -924,6 +924,13 @@ func (c *LeveledCompactor) populateSymbols(sets []storage.ChunkSeriesSet, outBlo
batchers := make([]*symbolsBatcher, len(outBlocks)) batchers := make([]*symbolsBatcher, len(outBlocks))
for ix := range outBlocks { for ix := range outBlocks {
batchers[ix] = newSymbolsBatcher(10000, outBlocks[ix].tmpDir) batchers[ix] = newSymbolsBatcher(10000, outBlocks[ix].tmpDir)
// Always include empty symbol. Blocks created from Head always have it in the symbols table,
// and if we only include symbols from series, we would skip it.
// It may not be required, but it's small and better be safe than sorry.
if err := batchers[ix].addSymbol(""); err != nil {
return errors.Wrap(err, "addSymbol to batcher")
}
} }
seriesSet := sets[0] seriesSet := sets[0]

View file

@ -562,6 +562,11 @@ func TestCompaction_CompactWithSplitting(t *testing.T) {
// Symbols found in series. // Symbols found in series.
seriesSymbols := map[string]struct{}{} seriesSymbols := map[string]struct{}{}
// We always expect to find "" symbol in the symbols table even if it's not in the series.
// Head compaction always includes it, and then it survives additional non-sharded compactions.
// Our splitting compaction preserves it too.
seriesSymbols[""] = struct{}{}
block, err := OpenBlock(log.NewNopLogger(), filepath.Join(dir, blockID.String()), nil) block, err := OpenBlock(log.NewNopLogger(), filepath.Join(dir, blockID.String()), nil)
require.NoError(t, err) require.NoError(t, err)
@ -601,14 +606,6 @@ func TestCompaction_CompactWithSplitting(t *testing.T) {
symIt := idxr.Symbols() symIt := idxr.Symbols()
for symIt.Next() { for symIt.Next() {
w := symIt.At() w := symIt.At()
// When shardCount == 1, we're not doing symbols splitting. Head-compacted blocks
// however do have empty string as a symbol in the table.
// Since label name or value cannot be empty string, we will never find it in seriesSymbols.
if w == "" && shardCount <= 1 {
continue
}
_, ok := seriesSymbols[w] _, ok := seriesSymbols[w]
require.True(t, ok, "not found in series: '%s'", w) require.True(t, ok, "not found in series: '%s'", w)
delete(seriesSymbols, w) delete(seriesSymbols, w)