From 15b25a8c3d49c819a0d5f6c8c6c77139f07208f2 Mon Sep 17 00:00:00 2001 From: istae <14264581+istae@users.noreply.github.com> Date: Fri, 29 Sep 2023 03:38:56 +0300 Subject: [PATCH] fix: batch --- pkg/storer/compact.go | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/pkg/storer/compact.go b/pkg/storer/compact.go index 1cb6ebc14f8..c9a2846c21b 100644 --- a/pkg/storer/compact.go +++ b/pkg/storer/compact.go @@ -91,6 +91,11 @@ func Compact(ctx context.Context, basePath string, opts *Options, validate bool) start := uint32(0) end := lastUsedSlot + batch, err := store.Batch(ctx) + if err != nil { + return err + } + for start < end { if slots[start] != nil { @@ -113,7 +118,7 @@ func Compact(ctx context.Context, basePath string, opts *Options, validate bool) } from.Location = to - if err := store.Put(from); err != nil { + if err := batch.Put(from); err != nil { return fmt.Errorf("store put: %w", err) } @@ -121,6 +126,10 @@ func Compact(ctx context.Context, basePath string, opts *Options, validate bool) end-- } + if err := batch.Commit(); err != nil { + return err + } + logger.Info("shard truncated", "shard", fmt.Sprintf("%d/%d", shard, sharkyNoOfShards-1), "slot", end) if err := sharkyRecover.TruncateAt(context.Background(), uint8(shard), end+1); err != nil {