lib/mergeset: tune compression levels in order to improve ingestion performance a bit

This commit is contained in:
Aliaksandr Valialkin 2020-05-14 23:44:01 +03:00
parent 1b5d272e07
commit 6838fa876c
2 changed files with 25 additions and 9 deletions

View File

@ -151,7 +151,7 @@ var isInTest = func() bool {
return strings.HasSuffix(os.Args[0], ".test") return strings.HasSuffix(os.Args[0], ".test")
}() }()
// MarshalUnsortedData marshals sorted items from ib to sb. // MarshalSortedData marshals sorted items from ib to sb.
// //
// It also: // It also:
// - appends first item to firstItemDst and returns the result. // - appends first item to firstItemDst and returns the result.

View File

@ -624,7 +624,9 @@ func (tb *Table) mergeInmemoryBlocks(blocksToMerge []*inmemoryBlock) *partWrappe
// Prepare blockStreamWriter for destination part. // Prepare blockStreamWriter for destination part.
bsw := getBlockStreamWriter() bsw := getBlockStreamWriter()
compressLevel := 1 // Use the minimum compression level for in-memory blocks,
// since they are going to be re-compressed during the merge into file-based blocks.
compressLevel := -5 // See https://github.com/facebook/zstd/releases/tag/v1.3.4
mpDst := getInmemoryPart() mpDst := getInmemoryPart()
bsw.InitFromInmemoryPart(mpDst, compressLevel) bsw.InitFromInmemoryPart(mpDst, compressLevel)
@ -876,19 +878,33 @@ func (tb *Table) mergeParts(pws []*partWrapper, stopCh <-chan struct{}, isOuterP
} }
func getCompressLevelForPartItems(itemsCount uint64) int { func getCompressLevelForPartItems(itemsCount uint64) int {
if itemsCount < 1<<19 { if itemsCount <= 1<<16 {
// -5 is the minimum supported compression for zstd.
// See https://github.com/facebook/zstd/releases/tag/v1.3.4
return -5
}
if itemsCount <= 1<<17 {
return -4
}
if itemsCount <= 1<<18 {
return -3
}
if itemsCount <= 1<<19 {
return -2
}
if itemsCount <= 1<<20 {
return -1
}
if itemsCount <= 1<<22 {
return 1 return 1
} }
if itemsCount < 1<<22 { if itemsCount <= 1<<25 {
return 2 return 2
} }
if itemsCount < 1<<25 { if itemsCount <= 1<<28 {
return 3 return 3
} }
if itemsCount < 1<<28 { return 4
return 4
}
return 5
} }
func (tb *Table) nextMergeIdx() uint64 { func (tb *Table) nextMergeIdx() uint64 {