Skip to content

Commit

Permalink
Benchmarks and optimizations
Browse files Browse the repository at this point in the history
  • Loading branch information
sfc-gh-sili committed Jan 14, 2025
1 parent d156151 commit e86780d
Show file tree
Hide file tree
Showing 3 changed files with 70 additions and 15 deletions.
5 changes: 3 additions & 2 deletions exporter/exporterhelper/logs.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,9 @@ var (
)

type logsRequest struct {
ld plog.Logs
pusher consumer.ConsumeLogsFunc
ld plog.Logs
pusher consumer.ConsumeLogsFunc
byteSize int
}

func newLogsRequest(ld plog.Logs, pusher consumer.ConsumeLogsFunc) Request {
Expand Down
12 changes: 11 additions & 1 deletion exporter/exporterhelper/logs_batch.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,12 +46,22 @@ func (req *logsRequest) mergeSplitBasedOnByteSize(cfg exporterbatcher.MaxSizeCon
continue
}

ByteSize := srcReq.ld.ByteSize()
ByteSize := srcReq.byteSize
if ByteSize == 0 {
ByteSize = srcReq.ld.ByteSize()
}
if ByteSize > capacityLeft && capacityLeft < cfg.MaxSizeBytes {
res = append(res, destReq)
destReq = nil
capacityLeft = cfg.MaxSizeBytes
}

if ByteSize <= capacityLeft {
if destReq == nil {
destReq = srcReq
} else {
srcReq.ld.ResourceLogs().MoveAndAppendTo(destReq.ld.ResourceLogs())
destReq.byteSize += ByteSize
}
capacityLeft -= ByteSize
continue
Expand Down
68 changes: 56 additions & 12 deletions exporter/exporterhelper/logs_batch_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -252,42 +252,86 @@ func TestMergeSplitLogsBasedOnByteSize(t *testing.T) {
}
}

func BenchmarkSplittingBasedOnItemCountManyLogs(b *testing.B) {
cfg := exporterbatcher.MaxSizeConfig{MaxSizeItems: 10}
func BenchmarkSplittingBasedOnItemCountManySmallLogs(b *testing.B) {
cfg := exporterbatcher.MaxSizeConfig{MaxSizeItems: 10000}
for i := 0; i < b.N; i++ {
lr1 := &logsRequest{ld: testdata.GenerateLogs(9)}
lr1 := &logsRequest{ld: testdata.GenerateLogs(10)}
for j := 0; j < 1000; j++ {
lr2 := &logsRequest{ld: testdata.GenerateLogs(9)}
lr2 := &logsRequest{ld: testdata.GenerateLogs(10)}
lr1.MergeSplit(context.Background(), cfg, lr2)
}
}
}

func BenchmarkSplittingBasedOnByteSizeManyLogs(b *testing.B) {
cfg := exporterbatcher.MaxSizeConfig{MaxSizeBytes: 1010}
func BenchmarkSplittingBasedOnByteSizeManySmallLogs(b *testing.B) {
cfg := exporterbatcher.MaxSizeConfig{MaxSizeBytes: 1010000}
for i := 0; i < b.N; i++ {
lr1 := &logsRequest{ld: testdata.GenerateLogs(9)}
lr1 := &logsRequest{ld: testdata.GenerateLogs(10)}
for j := 0; j < 1000; j++ {
lr2 := &logsRequest{ld: testdata.GenerateLogs(9)}
lr2 := &logsRequest{ld: testdata.GenerateLogs(10)}
lr1.MergeSplit(context.Background(), cfg, lr2)
}
}
}

func BenchmarkSplittingBasedOnItemCountManyLogsSlightlyAboveLimit(b *testing.B) {
cfg := exporterbatcher.MaxSizeConfig{MaxSizeItems: 10000}
for i := 0; i < b.N; i++ {
lr1 := &logsRequest{ld: testdata.GenerateLogs(10001)}
for j := 0; j < 10; j++ {
lr2 := &logsRequest{ld: testdata.GenerateLogs(10001)}
lr1.MergeSplit(context.Background(), cfg, lr2)
}
}
}

func BenchmarkSplittingBasedOnByteSizeManyLogsSlightlyAboveLimit(b *testing.B) {
cfg := exporterbatcher.MaxSizeConfig{MaxSizeBytes: 960052} // 960052 corresponds to 10000 generated logs
for i := 0; i < b.N; i++ {
lr1 := &logsRequest{ld: testdata.GenerateLogs(10001)}
for j := 0; j < 10; j++ {
lr2 := &logsRequest{ld: testdata.GenerateLogs(10001)}
lr1.MergeSplit(context.Background(), cfg, lr2)
}
}
}

func BenchmarkSplittingBasedOnItemCountManyLogsSlightlyBelowLimit(b *testing.B) {
cfg := exporterbatcher.MaxSizeConfig{MaxSizeItems: 10000}
for i := 0; i < b.N; i++ {
lr1 := &logsRequest{ld: testdata.GenerateLogs(9999)}
for j := 0; j < 10; j++ {
lr2 := &logsRequest{ld: testdata.GenerateLogs(9999)}
lr1.MergeSplit(context.Background(), cfg, lr2)
}
}
}

func BenchmarkSplittingBasedOnByteSizeManyLogsSlightlyBelowLimit(b *testing.B) {
cfg := exporterbatcher.MaxSizeConfig{MaxSizeBytes: 960052} // 960052 corresponds to 10000 generated logs
for i := 0; i < b.N; i++ {
lr1 := &logsRequest{ld: testdata.GenerateLogs(9999)}
for j := 0; j < 10; j++ {
lr2 := &logsRequest{ld: testdata.GenerateLogs(9999)}
lr1.MergeSplit(context.Background(), cfg, lr2)
}
}
}

func BenchmarkSplittingBasedOnItemCountHugeLog(b *testing.B) {
cfg := exporterbatcher.MaxSizeConfig{MaxSizeItems: 10}
cfg := exporterbatcher.MaxSizeConfig{MaxSizeItems: 10000}
for i := 0; i < b.N; i++ {
lr1 := &logsRequest{ld: testdata.GenerateLogs(1)}
lr2 := &logsRequest{ld: testdata.GenerateLogs(1000)}
lr2 := &logsRequest{ld: testdata.GenerateLogs(100000)} // l2 is of size 9.600054 MB
lr1.MergeSplit(context.Background(), cfg, lr2)
}
}

func BenchmarkSplittingBasedOnByteSizeHugeLog(b *testing.B) {
cfg := exporterbatcher.MaxSizeConfig{MaxSizeBytes: 1010}
cfg := exporterbatcher.MaxSizeConfig{MaxSizeBytes: 970000}
for i := 0; i < b.N; i++ {
lr1 := &logsRequest{ld: testdata.GenerateLogs(1)}
lr2 := &logsRequest{ld: testdata.GenerateLogs(1000)}
lr2 := &logsRequest{ld: testdata.GenerateLogs(100000)}
lr1.MergeSplit(context.Background(), cfg, lr2)
}
}

0 comments on commit e86780d

Please sign in to comment.