0820681560
Resolves: bz#1547903 bz#1566336 bz#1568896 bz#1578716 bz#1581047 Resolves: bz#1581231 bz#1582066 bz#1593865 bz#1597506 bz#1597511 Resolves: bz#1597654 bz#1597768 bz#1598105 bz#1598356 bz#1599037 Resolves: bz#1599823 bz#1600057 bz#1601314 Signed-off-by: Milind Changire <mchangir@redhat.com>
115 lines
3.8 KiB
Diff
115 lines
3.8 KiB
Diff
From 8c9028b560b1f0fd816e7d2a9e0bec70cc526c1a Mon Sep 17 00:00:00 2001
|
|
From: Kotresh HR <khiremat@redhat.com>
|
|
Date: Sat, 7 Jul 2018 08:58:08 -0400
|
|
Subject: [PATCH 317/325] geo-rep/scheduler: Fix EBUSY trace back
|
|
|
|
Fix the trace back during temporary mount
|
|
cleanup. Temporary mount is done to touch
|
|
the root required for checkpoint to complete.
|
|
|
|
Backport of
|
|
> Patch: https://review.gluster.org/#/c/20476/
|
|
> BUG: 1598977
|
|
> Change-Id: I97fea538e92c4ef0747747e981ef98499504e336
|
|
> Signed-off-by: Kotresh HR <khiremat@redhat.com>
|
|
|
|
BUG: 1568896
|
|
Change-Id: I97fea538e92c4ef0747747e981ef98499504e336
|
|
Signed-off-by: Kotresh HR <khiremat@redhat.com>
|
|
Reviewed-on: https://code.engineering.redhat.com/gerrit/143949
|
|
Tested-by: RHGS Build Bot <nigelb@redhat.com>
|
|
Reviewed-by: Sunil Kumar Heggodu Gopala Acharya <sheggodu@redhat.com>
|
|
---
|
|
extras/geo-rep/schedule_georep.py.in | 25 ++++++++++++++++++++-----
|
|
1 file changed, 20 insertions(+), 5 deletions(-)
|
|
|
|
diff --git a/extras/geo-rep/schedule_georep.py.in b/extras/geo-rep/schedule_georep.py.in
|
|
index 4e1a071..3797fff 100644
|
|
--- a/extras/geo-rep/schedule_georep.py.in
|
|
+++ b/extras/geo-rep/schedule_georep.py.in
|
|
@@ -43,7 +43,7 @@ SESSION_MOUNT_LOG_FILE = ("/var/log/glusterfs/geo-replication"
|
|
"/schedule_georep.mount.log")
|
|
|
|
USE_CLI_COLOR = True
|
|
-
|
|
+mnt_list = []
|
|
|
|
class GlusterBadXmlFormat(Exception):
|
|
"""
|
|
@@ -90,6 +90,8 @@ def execute(cmd, success_msg="", failure_msg="", exitcode=-1):
|
|
output_ok(success_msg)
|
|
return out
|
|
else:
|
|
+ if exitcode == 0:
|
|
+ return
|
|
err_msg = err if err else out
|
|
output_notok(failure_msg, err=err_msg, exitcode=exitcode)
|
|
|
|
@@ -112,12 +114,12 @@ def cleanup(hostname, volname, mnt):
|
|
"""
|
|
Unmount the Volume and Remove the temporary directory
|
|
"""
|
|
- execute(["umount", mnt],
|
|
+ execute(["umount", "-l", mnt],
|
|
failure_msg="Unable to Unmount Gluster Volume "
|
|
"{0}:{1}(Mounted at {2})".format(hostname, volname, mnt))
|
|
execute(["rmdir", mnt],
|
|
failure_msg="Unable to Remove temp directory "
|
|
- "{0}".format(mnt))
|
|
+ "{0}".format(mnt), exitcode=0)
|
|
|
|
|
|
@contextmanager
|
|
@@ -130,6 +132,7 @@ def glustermount(hostname, volname):
|
|
Automatically unmounts it in case of Exceptions/out of context
|
|
"""
|
|
mnt = tempfile.mkdtemp(prefix="georepsetup_")
|
|
+ mnt_list.append(mnt)
|
|
execute(["@SBIN_DIR@/glusterfs",
|
|
"--volfile-server", hostname,
|
|
"--volfile-id", volname,
|
|
@@ -378,14 +381,14 @@ def main(args):
|
|
output_ok("Started Geo-replication and watching Status for "
|
|
"Checkpoint completion")
|
|
|
|
- touch_mount_root(args.mastervol)
|
|
-
|
|
start_time = int(time.time())
|
|
duration = 0
|
|
|
|
# Sleep till Geo-rep initializes
|
|
time.sleep(60)
|
|
|
|
+ touch_mount_root(args.mastervol)
|
|
+
|
|
slave_url = "{0}::{1}".format(args.slave, args.slavevol)
|
|
|
|
# Loop to Check the Geo-replication Status and Checkpoint
|
|
@@ -446,6 +449,11 @@ def main(args):
|
|
|
|
time.sleep(args.interval)
|
|
|
|
+ for mnt in mnt_list:
|
|
+ execute(["rmdir", mnt],
|
|
+ failure_msg="Unable to Remove temp directory "
|
|
+ "{0}".format(mnt), exitcode=0)
|
|
+
|
|
if __name__ == "__main__":
|
|
parser = ArgumentParser(formatter_class=RawDescriptionHelpFormatter,
|
|
description=__doc__)
|
|
@@ -474,4 +482,11 @@ if __name__ == "__main__":
|
|
execute(cmd)
|
|
main(args)
|
|
except KeyboardInterrupt:
|
|
+ for mnt in mnt_list:
|
|
+ execute(["umount", "-l", mnt],
|
|
+ failure_msg="Unable to Unmount Gluster Volume "
|
|
+ "Mounted at {0}".format(mnt), exitcode=0)
|
|
+ execute(["rmdir", mnt],
|
|
+ failure_msg="Unable to Remove temp directory "
|
|
+ "{0}".format(mnt), exitcode=0)
|
|
output_notok("Exiting...")
|
|
--
|
|
1.8.3.1
|
|
|