From 2fb6b53fc1d53e7585e746016c6092fb59842176 Mon Sep 17 00:00:00 2001 From: Injun Song Date: Fri, 23 Feb 2024 01:06:05 +0900 Subject: [PATCH] test(storage): add GLSN log scan performance benchmark This PR introduces a new benchmark, BenchmarkStorage_ScanWithGLSN, to measure storage performance when scanning with GLSN across various scan sizes. The benchmark will serve as foundational data for performance optimization efforts. Changes: - Implemented the BenchmarkStorage_ScanWithGLSN benchmark - Added logic to measure performance across different scan sizes - Laid groundwork for recording and analyzing performance measurement results --- internal/storage/benchmark_test.go | 67 ++++++++++++++++++++++++++++++ 1 file changed, 67 insertions(+) diff --git a/internal/storage/benchmark_test.go b/internal/storage/benchmark_test.go index a2aa7d812..6383629d1 100644 --- a/internal/storage/benchmark_test.go +++ b/internal/storage/benchmark_test.go @@ -5,8 +5,10 @@ import ( "testing" "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/require" "github.com/kakao/varlog/pkg/types" + "github.com/kakao/varlog/proto/varlogpb" ) func BenchmarkStorage_WriteBatch(b *testing.B) { @@ -54,3 +56,68 @@ func BenchmarkStorage_WriteBatch(b *testing.B) { } } } + +func BenchmarkStorage_ScanWithGLSN(b *testing.B) { + numLogsList := []int{ + 1, 10, 100, 1000, + } + + for _, numLogs := range numLogsList { + b.Run(fmt.Sprintf("numLogs=%d", numLogs), func(b *testing.B) { + stg := TestNewStorage(b, + WithoutSync(), + WithDataDBOptions( + WithL0CompactionThreshold(2), + WithL0StopWritesThreshold(1000), + WithLBaseMaxBytes(64<<20), + WithMaxOpenFiles(16384), + WithMemTableSize(64<<20), + WithMemTableStopWritesThreshold(4), + WithMaxConcurrentCompaction(3), + ), + WithCommitDBOptions( + WithL0CompactionThreshold(2), + WithL0StopWritesThreshold(1000), + WithLBaseMaxBytes(64<<20), + WithMaxOpenFiles(16384), + WithMemTableSize(8<<20), + WithMemTableStopWritesThreshold(4), + WithMaxConcurrentCompaction(3), + ), + ) + b.Cleanup(func() { + assert.NoError(b, stg.Close()) + }) + + for i := range numLogs { + llsn := types.LLSN(i + 1) + glsn := types.GLSN(i + 1) + data := []byte(fmt.Sprintf("log entry %d", i+1)) + TestAppendLogEntryWithoutCommitContext(b, stg, llsn, glsn, data) + } + TestSetCommitContext(b, stg, CommitContext{ + Version: 1, + HighWatermark: types.GLSN(numLogs), + CommittedGLSNBegin: types.MinGLSN, + CommittedGLSNEnd: types.GLSN(numLogs + 1), + CommittedLLSNBegin: types.MinLLSN, + }) + + b.ResetTimer() + + var logEntry varlogpb.LogEntry + for range b.N { + scanner, err := stg.NewScanner(WithGLSN(types.MinGLSN, types.GLSN(numLogs+1))) + require.NoError(b, err) + for scanner.Valid() { + logEntry, err = scanner.Value() + require.NoError(b, err) + scanner.Next() + } + err = scanner.Close() + require.NoError(b, err) + } + _ = logEntry + }) + } +}