From 3beef10f89e7a33b2675e341d46672d9302c1369 Mon Sep 17 00:00:00 2001
From: Pavel Karpy
Date: Fri, 17 Feb 2023 17:23:09 +0300
Subject: [PATCH] [#61] node: Do not fetch missing objects
If an object is missing in a `meta`, shard should not look for it in
a `blobstor`.
Signed-off-by: Pavel Karpy
---
CHANGELOG.md | 1 +
pkg/local_object_storage/shard/get.go | 15 ++++++---------
2 files changed, 7 insertions(+), 9 deletions(-)
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 4e55921956..6b448e265f 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -39,6 +39,7 @@ Changelog for FrostFS Node
- Storage ID update by write-cache (#2244)
- `neo-go` client deadlock on subscription restoration (#2244)
- Possible panic during write-cache initialization (#2234)
+- Do not fetch an object if `meta` is missing it (#61)
### Removed
### Updated
diff --git a/pkg/local_object_storage/shard/get.go b/pkg/local_object_storage/shard/get.go
index 607d508d35..934684655e 100644
--- a/pkg/local_object_storage/shard/get.go
+++ b/pkg/local_object_storage/shard/get.go
@@ -102,16 +102,19 @@ func (s *Shard) fetchObjectData(addr oid.Address, skipMeta bool, cb storFetcher,
mRes meta.ExistsRes
)
- var exists bool
if !skipMeta {
var mPrm meta.ExistsPrm
mPrm.SetAddress(addr)
-
mRes, mErr = s.metaBase.Exists(mPrm)
if mErr != nil && !s.info.Mode.NoMetabase() {
return nil, false, mErr
}
- exists = mRes.Exists()
+
+ if !mRes.Exists() {
+ return nil, false, logicerr.Wrap(apistatus.ObjectNotFound{})
+ }
+ } else {
+ s.log.Warn("fetching object without meta", zap.Stringer("addr", addr))
}
if s.hasWriteCache() {
@@ -119,7 +122,6 @@ func (s *Shard) fetchObjectData(addr oid.Address, skipMeta bool, cb storFetcher,
if err == nil || IsErrOutOfRange(err) {
return res, false, err
}
-
if IsErrNotFound(err) {
s.log.Debug("object is missing in write-cache",
zap.Stringer("addr", addr),
@@ -131,16 +133,11 @@ func (s *Shard) fetchObjectData(addr oid.Address, skipMeta bool, cb storFetcher,
zap.Bool("skip_meta", skipMeta))
}
}
-
if skipMeta || mErr != nil {
res, err := cb(s.blobStor, nil)
return res, false, err
}
- if !exists {
- return nil, false, logicerr.Wrap(apistatus.ObjectNotFound{})
- }
-
var mPrm meta.StorageIDPrm
mPrm.SetAddress(addr)