]> git-server-git.apps.pok.os.sepia.ceph.com Git - ceph.git/commitdiff
rgw: fix data corruption due to network jitter 48274/head
authorlu.shasha <lu.shasha@aishu.cn>
Thu, 18 Aug 2022 07:07:42 +0000 (15:07 +0800)
committerSatoru Takeuchi <satoru.takeuchi@gmail.com>
Wed, 28 Sep 2022 02:46:02 +0000 (02:46 +0000)
In function RGWRados::Object::Write::_do_write_meta rgw_rados_operate may return -ETIMEDOUT due to network jitter.
But head obj may eventually be written successfully even if return -ETIMEDOUT. Due to r < 0, meta.canceled be set true.
In such scenario, all the tail objects will removed in the destructor of RadosWriter, then data corruptted.
To avoid data corruption, when return -ETIMEDOUT, should clear all objects in RadosWriter.

Signed-off-by: Shasha Lu <lu.shasha@aishu.cn>
(cherry picked from commit 04282ae3c1d19bf185ee1df148eb84deb244630f)

src/rgw/rgw_putobj_processor.cc

index 68730173edfb68986a9b9180591f219b9d7e8dbe..a4baa2308a370248b1e7fbf032b866f944077cf5 100644 (file)
@@ -310,6 +310,11 @@ int AtomicObjectProcessor::complete(size_t accounted_size,
 
   r = obj_op->prepare(y);
   if (r < 0) {
+    if (r == -ETIMEDOUT) {
+      // The head object write may eventually succeed, clear the set of objects for deletion. if it
+      // doesn't ever succeed, we'll orphan any tail objects as if we'd crashed before that write
+      writer.clear_written();
+    }
     return r;
   }