From e0e4f1f7ee1250d0547838950ea8978540c08067 Mon Sep 17 00:00:00 2001 From: Evgenii Stratonikov Date: Wed, 8 Jun 2022 14:03:29 +0300 Subject: [PATCH] engine: initialize shards in parallel Signed-off-by: Evgenii Stratonikov --- pkg/local_object_storage/engine/control.go | 20 ++++++++++++++++++-- 1 file changed, 18 insertions(+), 2 deletions(-) diff --git a/pkg/local_object_storage/engine/control.go b/pkg/local_object_storage/engine/control.go index f57536511..f2ea266c2 100644 --- a/pkg/local_object_storage/engine/control.go +++ b/pkg/local_object_storage/engine/control.go @@ -3,7 +3,9 @@ package engine import ( "errors" "fmt" + "sync" + "github.com/nspcc-dev/neofs-node/pkg/local_object_storage/shard" "go.uber.org/zap" ) @@ -16,9 +18,23 @@ func (e *StorageEngine) open() error { e.mtx.RLock() defer e.mtx.RUnlock() + var wg sync.WaitGroup + var errCh = make(chan error, len(e.shards)) for id, sh := range e.shards { - if err := sh.Open(); err != nil { - return fmt.Errorf("could not open shard %s: %w", id, err) + wg.Add(1) + go func(id string, sh *shard.Shard) { + defer wg.Done() + if err := sh.Open(); err != nil { + errCh <- fmt.Errorf("could not open shard %s: %w", id, err) + } + }(id, sh.Shard) + } + wg.Wait() + close(errCh) + + for err := range errCh { + if err != nil { + return err } }