diff --git a/turbo/snapshotsync/block_snapshots.go b/turbo/snapshotsync/block_snapshots.go index 2747fd556db700eab1e61381339b8d74d6be0d46..04e8d40c30de552a3d8f0d4cc9e04eecd9c7ba47 100644 --- a/turbo/snapshotsync/block_snapshots.go +++ b/turbo/snapshotsync/block_snapshots.go @@ -449,10 +449,10 @@ func (s *RoSnapshots) AsyncOpenAll(ctx context.Context) { return default: } - if err := s.ReopenSegments(); err != nil && !errors.Is(err, os.ErrNotExist) { + if err := s.ReopenSegments(); err != nil && !errors.Is(err, os.ErrNotExist) && !errors.Is(err, ErrSnapshotMissed) { log.Error("AsyncOpenAll", "err", err) } - if err := s.ReopenIndices(); err != nil && !errors.Is(err, os.ErrNotExist) { + if err := s.ReopenIndices(); err != nil && !errors.Is(err, os.ErrNotExist) && !errors.Is(err, ErrSnapshotMissed) { log.Error("AsyncOpenAll", "err", err) } time.Sleep(15 * time.Second) @@ -709,6 +709,8 @@ func TmpFiles(dir string) (res []string, err error) { return res, nil } +var ErrSnapshotMissed = fmt.Errorf("snapshot missed") + func noGaps(in []FileInfo) (out []FileInfo, err error) { var prevTo uint64 for _, f := range in { @@ -716,7 +718,7 @@ func noGaps(in []FileInfo) (out []FileInfo, err error) { continue } if f.From != prevTo { // no gaps - return nil, fmt.Errorf("snapshot missed: from %d to %d", prevTo, f.From) + return nil, fmt.Errorf("%w: from %d to %d", ErrSnapshotMissed, prevTo, f.From) } prevTo = f.To out = append(out, f)