volume server: remote tier volumes only soft delete in local index

fix https://github.com/seaweedfs/seaweedfs/issues/3889
This commit is contained in:
chrislu 2022-10-23 13:04:38 -07:00
parent 25471d579a
commit 184fbb6c50

View File

@ -213,13 +213,17 @@ func (v *Volume) doDeleteRequest(n *needle.Needle) (Size, error) {
nv, ok := v.nm.Get(n.Id) nv, ok := v.nm.Get(n.Id)
// fmt.Println("key", n.Id, "volume offset", nv.Offset, "data_size", n.Size, "cached size", nv.Size) // fmt.Println("key", n.Id, "volume offset", nv.Offset, "data_size", n.Size, "cached size", nv.Size)
if ok && nv.Size.IsValid() { if ok && nv.Size.IsValid() {
size := nv.Size var offset uint64
n.Data = nil var err error
n.AppendAtNs = uint64(time.Now().UnixNano()) if !v.hasRemoteFile {
offset, _, _, err := n.Append(v.DataBackend, v.Version()) size := nv.Size
v.checkReadWriteError(err) n.Data = nil
if err != nil { n.AppendAtNs = uint64(time.Now().UnixNano())
return size, err offset, _, _, err = n.Append(v.DataBackend, v.Version())
v.checkReadWriteError(err)
if err != nil {
return size, err
}
} }
v.lastAppendAtNs = n.AppendAtNs v.lastAppendAtNs = n.AppendAtNs
if err = v.nm.Delete(n.Id, ToOffset(int64(offset))); err != nil { if err = v.nm.Delete(n.Id, ToOffset(int64(offset))); err != nil {