1f2f23ddef
Resolves: bz#1350745 bz#1362129 bz#1541568 bz#1597252 bz#1599220 Resolves: bz#1633177 bz#1637564 bz#1639476 bz#1639568 bz#1643370 Resolves: bz#1645480 bz#1648296 bz#1648893 bz#1651040 bz#1651460 Resolves: bz#1652466 bz#1652537 bz#1653224 bz#1653613 bz#1654103 Resolves: bz#1654161 bz#1655385 bz#1655578 bz#1656357 bz#1659439 Signed-off-by: Milind Changire <mchangir@redhat.com>
92 lines
3.5 KiB
Diff
92 lines
3.5 KiB
Diff
From adeeec1fbe7241d18903ae3830a1fabb1061be21 Mon Sep 17 00:00:00 2001
|
|
From: karthik-us <ksubrahm@redhat.com>
|
|
Date: Mon, 17 Dec 2018 14:28:07 +0530
|
|
Subject: [PATCH 489/493] cluster/afr: Do not update read_subvol in inode_ctx
|
|
after rename/link fop
|
|
|
|
Since rename/link fops on a file will not change any data in it, it should
|
|
not update the read_subvol values in the inode_ctx, which interprets the
|
|
data & metadata readable subvols for that file. The old read_subvol values
|
|
should be retained even after the rename/link operations.
|
|
|
|
Backport of: https://review.gluster.org/#/c/glusterfs/+/21841
|
|
|
|
Change-Id: I22787938b3f8295a48162ab4f498e4010d66a1ab
|
|
BUG: 1645480
|
|
Signed-off-by: karthik-us <ksubrahm@redhat.com>
|
|
Reviewed-on: https://code.engineering.redhat.com/gerrit/158803
|
|
Tested-by: RHGS Build Bot <nigelb@redhat.com>
|
|
Tested-by: Ravishankar Narayanankutty <ravishankar@redhat.com>
|
|
Reviewed-by: Ravishankar Narayanankutty <ravishankar@redhat.com>
|
|
Reviewed-by: Sunil Kumar Heggodu Gopala Acharya <sheggodu@redhat.com>
|
|
---
|
|
...7783-do-not-update-read-subvol-on-rename-link.t | 40 ++++++++++++++++++++++
|
|
xlators/cluster/afr/src/afr-dir-write.c | 4 ++-
|
|
2 files changed, 43 insertions(+), 1 deletion(-)
|
|
create mode 100644 tests/bugs/replicate/bug-1657783-do-not-update-read-subvol-on-rename-link.t
|
|
|
|
diff --git a/tests/bugs/replicate/bug-1657783-do-not-update-read-subvol-on-rename-link.t b/tests/bugs/replicate/bug-1657783-do-not-update-read-subvol-on-rename-link.t
|
|
new file mode 100644
|
|
index 0000000..b180f0e
|
|
--- /dev/null
|
|
+++ b/tests/bugs/replicate/bug-1657783-do-not-update-read-subvol-on-rename-link.t
|
|
@@ -0,0 +1,40 @@
|
|
+#!/bin/bash
|
|
+. $(dirname $0)/../../include.rc
|
|
+. $(dirname $0)/../../volume.rc
|
|
+cleanup;
|
|
+
|
|
+TEST glusterd
|
|
+TEST pidof glusterd
|
|
+TEST $CLI volume create $V0 replica 3 $H0:$B0/${V0}{0..2}
|
|
+TEST $CLI volume set $V0 self-heal-daemon off
|
|
+TEST $CLI volume set $V0 cluster.data-self-heal off
|
|
+TEST $CLI volume set $V0 cluster.metadata-self-heal off
|
|
+TEST $CLI volume set $V0 cluster.entry-self-heal off
|
|
+TEST $CLI volume set $V0 performance.write-behind off
|
|
+
|
|
+TEST $CLI volume start $V0
|
|
+TEST $GFS --volfile-id=$V0 --volfile-server=$H0 $M0;
|
|
+TEST mkdir $M0/dir
|
|
+TEST "echo abc > $M0/file1"
|
|
+TEST "echo uvw > $M0/file2"
|
|
+
|
|
+TEST kill_brick $V0 $H0 $B0/${V0}0
|
|
+TEST "echo def > $M0/file1"
|
|
+TEST "echo xyz > $M0/file2"
|
|
+
|
|
+TEST $CLI volume start $V0 force
|
|
+EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" brick_up_status $V0 $H0 $B0/${V0}0
|
|
+EXPECT_WITHIN $PROCESS_UP_TIMEOUT "1" afr_child_up_status $V0 0
|
|
+
|
|
+TEST kill_brick $V0 $H0 $B0/${V0}1
|
|
+
|
|
+# Rename file1 and read it. Read should be served from the 3rd brick
|
|
+TEST mv $M0/file1 $M0/file3
|
|
+EXPECT "def" cat $M0/file3
|
|
+
|
|
+# Create a link to file2 and read it. Read should be served from the 3rd brick
|
|
+TEST ln $M0/file2 $M0/dir/file4
|
|
+EXPECT "xyz" cat $M0/dir/file4
|
|
+EXPECT "xyz" cat $M0/file2
|
|
+
|
|
+cleanup
|
|
diff --git a/xlators/cluster/afr/src/afr-dir-write.c b/xlators/cluster/afr/src/afr-dir-write.c
|
|
index 75889de..c508034 100644
|
|
--- a/xlators/cluster/afr/src/afr-dir-write.c
|
|
+++ b/xlators/cluster/afr/src/afr-dir-write.c
|
|
@@ -99,7 +99,9 @@ __afr_dir_write_finalize (call_frame_t *frame, xlator_t *this)
|
|
}
|
|
|
|
if (local->inode) {
|
|
- afr_replies_interpret (frame, this, local->inode, NULL);
|
|
+ if (local->op != GF_FOP_RENAME && local->op != GF_FOP_LINK)
|
|
+ afr_replies_interpret (frame, this, local->inode, NULL);
|
|
+
|
|
inode_read_subvol = afr_data_subvol_get (local->inode, this,
|
|
NULL, NULL, NULL, &args);
|
|
}
|
|
--
|
|
1.8.3.1
|
|
|