[pve-devel] [PATCH ha-manager v2] get_pve_lock: allow retrying if pmxcfs is offline
Thomas Lamprecht
t.lamprecht at proxmox.com
Tue Nov 15 12:26:59 CET 2016
Our cluster filesystem is for a short time offline when its package
(pve-cluster) gets updated.
If them LRM or CRM call the get_protected_ha_*_lock during such a
time it run into this check and died.
As a result we assumed that we lost our lock and change in the
'lost_agent_lock' state. Then the watchdog updates were stopped to
allow selfencing.
This fencing is completely unnecessary, so retry again instead, up to
5 times. After that we can assume that pmxcfs is dead and swicth in
the 'lost_agent_lock' state.
Signed-off-by: Thomas Lamprecht <t.lamprecht at proxmox.com>
---
changes since v1:
* set $retry instead of a sensless return as we are in a eval...
src/PVE/HA/Env/PVE2.pm | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/src/PVE/HA/Env/PVE2.pm b/src/PVE/HA/Env/PVE2.pm
index 6b8802e..3141e1e 100644
--- a/src/PVE/HA/Env/PVE2.pm
+++ b/src/PVE/HA/Env/PVE2.pm
@@ -227,7 +227,10 @@ sub get_pve_lock {
mkdir $lockdir;
# pve cluster filesystem not online
- die "can't create '$lockdir' (pmxcfs not mounted?)\n" if ! -d $lockdir;
+ if (! -d $lockdir) {
+ $retry = 1;
+ die "can't create '$lockdir' (pmxcfs not mounted?)\n";
+ }
if ($last && (($ctime - $last) < $retry_timeout)) {
# send cfs lock update request (utime)
--
2.1.4
More information about the pve-devel
mailing list