From 59748b7ae8cea56738a6a72933a498daf5d37c94 Mon Sep 17 00:00:00 2001 From: Evgenii Stratonikov Date: Mon, 6 Feb 2023 13:48:58 +0300 Subject: [PATCH] [#2238] neofs-node: Gracefully handle shard initialization errors Signed-off-by: Evgenii Stratonikov --- cmd/frostfs-node/config.go | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/cmd/frostfs-node/config.go b/cmd/frostfs-node/config.go index d20e9b1cc4..9d47e43cb2 100644 --- a/cmd/frostfs-node/config.go +++ b/cmd/frostfs-node/config.go @@ -790,13 +790,18 @@ func initLocalStorage(c *cfg) { tombstone.WithTombstoneSource(tombstoneSrc), ) + var shardsAttached int for _, optsWithMeta := range c.shardOpts() { id, err := ls.AddShard(append(optsWithMeta.shOpts, shard.WithTombstoneSource(tombstoneSource))...) - fatalOnErr(err) - - c.log.Info("shard attached to engine", - zap.Stringer("id", id), - ) + if err != nil { + c.log.Error("failed to attach shard to engine", zap.Error(err)) + } else { + shardsAttached++ + c.log.Info("shard attached to engine", zap.Stringer("id", id)) + } + } + if shardsAttached == 0 { + fatalOnErr(engineconfig.ErrNoShardConfigured) } c.cfgObject.cfgLocalStorage.localStorage = ls