[#959] shard: Skip rebuild in `DEGRADED` mode

Signed-off-by: Anton Nikiforov <an.nikiforov@yadro.com>
pull/987/head
Anton Nikiforov 2024-02-14 15:39:28 +03:00
parent 5cbf57081f
commit 2429508ac5
1 changed files with 8 additions and 5 deletions

View File

@ -173,8 +173,9 @@ func (s *Shard) Init(ctx context.Context) error {
s.gc.init(ctx)
s.rb = newRebuilder(s.rebuildLimiter)
s.rb.Start(ctx, s.blobStor, s.metaBase, s.log)
if !m.NoMetabase() {
s.rb.Start(ctx, s.blobStor, s.metaBase, s.log)
}
return nil
}
@ -327,9 +328,11 @@ func (s *Shard) Reload(ctx context.Context, opts ...Option) error {
defer unlock()
s.rb.Stop(s.log)
defer func() {
s.rb.Start(ctx, s.blobStor, s.metaBase, s.log)
}()
if !s.info.Mode.NoMetabase() {
defer func() {
s.rb.Start(ctx, s.blobStor, s.metaBase, s.log)
}()
}
ok, err := s.metaBase.Reload(c.metaOpts...)
if err != nil {