From 09f4613a082f07bad2419f5e714e97773afc68d9 Mon Sep 17 00:00:00 2001 From: Jeronimo Irazabal Date: Mon, 7 Nov 2022 11:00:40 -0300 Subject: [PATCH] fix(embedded/appendable): fsync parent folder in remote appedable Signed-off-by: Jeronimo Irazabal --- embedded/appendable/remoteapp/remote_app.go | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/embedded/appendable/remoteapp/remote_app.go b/embedded/appendable/remoteapp/remote_app.go index b1db06d387..c7da855d65 100644 --- a/embedded/appendable/remoteapp/remote_app.go +++ b/embedded/appendable/remoteapp/remote_app.go @@ -32,6 +32,7 @@ import ( "time" "github.com/codenotary/immudb/embedded/appendable" + "github.com/codenotary/immudb/embedded/appendable/fileutils" "github.com/codenotary/immudb/embedded/appendable/multiapp" "github.com/codenotary/immudb/embedded/appendable/singleapp" "github.com/codenotary/immudb/embedded/cache" @@ -264,7 +265,12 @@ func (r *RemoteStorageAppendable) uploadChunk(chunkID int64, dontRemoveFile bool r.chunkInfos[chunkID].cancelUpload = nil r.mutex.Unlock() - return os.Remove(path.Join(r.path, appName)) + err := os.Remove(path.Join(r.path, appName)) + if err != nil { + return nil + } + + return fileutils.SyncDir(r.path) }) if ctx.Err() != nil { @@ -354,7 +360,12 @@ func (r *RemoteStorageAppendable) downloadChunk(chunkID int64) { return flTmp.Close() }) cp.Step(func() error { - return os.Rename(fileNameTmp, fileName) + err := os.Rename(fileNameTmp, fileName) + if err != nil { + return err + } + + return fileutils.SyncDir(r.path) }) if ctx.Err() != nil {