[Kimchi-devel] [PATCH 2/3] Github bug #327: NFS pool workaround: timeout adjustments
Daniel Barboza
danielhb at linux.vnet.ibm.com
Tue Feb 25 16:33:02 UTC 2014
From: Daniel Henrique Barboza <danielhb at linux.vnet.ibm.com>
Adding a smaller timeout in the 'prepare()' method of
libvirtstoragepool ('mount' and 'umount' commands).
Fixing an error in utils/run_command() that prevented the
TimeoutExpired exception to be raised sometimes.
Signed-off-by: Daniel Henrique Barboza <danielhb at linux.vnet.ibm.com>
---
src/kimchi/model/libvirtstoragepool.py | 9 ++++++---
src/kimchi/utils.py | 2 +-
2 files changed, 7 insertions(+), 4 deletions(-)
diff --git a/src/kimchi/model/libvirtstoragepool.py b/src/kimchi/model/libvirtstoragepool.py
index dc38d50..e69971b 100644
--- a/src/kimchi/model/libvirtstoragepool.py
+++ b/src/kimchi/model/libvirtstoragepool.py
@@ -94,15 +94,18 @@ class NetfsPoolDef(StoragePoolDef):
export_path, mnt_point]
umount_cmd = ["umount", "-f", export_path]
mounted = False
+ # 2 seconds looks like a reasonable time to wait for a refresh
+ # in the UI and enough time to verify that the NFS server
+ # is down.
+ cmd_timeout = 2
with RollbackContext() as rollback:
rollback.prependDefer(os.rmdir, mnt_point)
try:
- run_command(mount_cmd, 30)
- rollback.prependDefer(run_command, umount_cmd)
+ run_command(mount_cmd, cmd_timeout)
+ rollback.prependDefer(run_command, umount_cmd, cmd_timeout)
except TimeoutExpired:
raise InvalidParameter("KCHPOOL0012E", {'path': export_path})
-
with open("/proc/mounts", "rb") as f:
rawMounts = f.read()
output_items = ['dev_path', 'mnt_point', 'type']
diff --git a/src/kimchi/utils.py b/src/kimchi/utils.py
index 6be1c04..d4ab1a1 100644
--- a/src/kimchi/utils.py
+++ b/src/kimchi/utils.py
@@ -177,7 +177,7 @@ def run_command(cmd, timeout=None):
"timeout %s seconds" % timeout)
kimchi_log.error(msg)
- msg_args = {'cmd': cmd, 'seconds': timeout}
+ msg_args = {'cmd': " ".join(cmd), 'seconds': str(timeout)}
raise TimeoutExpired("KCHUTILS0002E", msg_args)
return out, error, proc.returncode
--
1.8.3.1
More information about the Kimchi-devel
mailing list