From ef541972f8c456c003cfcef7ceefb450dedf808b Mon Sep 17 00:00:00 2001
From: Konstantin Lebedev <9497591+kmlebedev@users.noreply.github.com>
Date: Tue, 8 Feb 2022 00:10:53 +0500
Subject: [PATCH] updated needle with fsync

---
 weed/storage/volume_vacuum.go | 9 +++++++++
 1 file changed, 9 insertions(+)

diff --git a/weed/storage/volume_vacuum.go b/weed/storage/volume_vacuum.go
index d686e2b09..56e8beddb 100644
--- a/weed/storage/volume_vacuum.go
+++ b/weed/storage/volume_vacuum.go
@@ -289,6 +289,9 @@ func (v *Volume) makeupDiff(newDatFileName, newIdxFileName, oldDatFileName, oldI
 				return fmt.Errorf("ReadNeedleBlob %s key %d offset %d size %d failed: %v", oldDatFile.Name(), key, increIdxEntry.offset.ToActualOffset(), increIdxEntry.size, err)
 			}
 			dstDatBackend.Write(needleBytes)
+			if err := dstDatBackend.Sync(); err != nil {
+				return fmt.Errorf("cannot sync needle %s: %v", dstDatBackend.File.Name(), err)
+			}
 			util.Uint32toBytes(idxEntryBytes[8:12], uint32(offset/NeedlePaddingSize))
 		} else { //deleted needle
 			//fakeDelNeedle 's default Data field is nil
@@ -308,6 +311,12 @@ func (v *Volume) makeupDiff(newDatFileName, newIdxFileName, oldDatFileName, oldI
 				newIdxFileName, err)
 		}
 		_, err = idx.Write(idxEntryBytes)
+		if err != nil {
+			return fmt.Errorf("cannot write indexfile %s: %v", newIdxFileName, err)
+		}
+		if err := idx.Sync(); err != nil {
+			return fmt.Errorf("cannot sync indexfile %s: %v", newIdxFileName, err)
+		}
 	}
 
 	return nil