61 lines
2.0 KiB
Diff
61 lines
2.0 KiB
Diff
From 824fe834c67fb7bae7feb87607381f9fa8fa2945 Mon Sep 17 00:00:00 2001
|
|
From: Klaus Wenninger <klaus.wenninger@aon.at>
|
|
Date: Fri, 7 Jun 2019 19:09:06 +0200
|
|
Subject: [PATCH] Fix: sbd-pacemaker: assume graceful exit if leftovers are
|
|
unmanged
|
|
|
|
---
|
|
src/sbd-pacemaker.c | 32 +++++++++++++++++++++++++++++++-
|
|
1 file changed, 31 insertions(+), 1 deletion(-)
|
|
|
|
diff --git a/src/sbd-pacemaker.c b/src/sbd-pacemaker.c
|
|
index 9a8b95f..2b35ff6 100644
|
|
--- a/src/sbd-pacemaker.c
|
|
+++ b/src/sbd-pacemaker.c
|
|
@@ -333,11 +333,41 @@ compute_status(pe_working_set_t * data_set)
|
|
}
|
|
}
|
|
|
|
+ /* If we are in shutdown-state once this will go on till the end.
|
|
+ * If we've on top reached a state of 0 locally running resources
|
|
+ * we can assume a clean shutdown.
|
|
+ * Tricky are the situations where the node is in maintenance-mode
|
|
+ * or resources are unmanaged. So if the node is in maintenance or
|
|
+ * all left-over running resources are unmanaged we assume intention.
|
|
+ */
|
|
if (node->details->shutdown) {
|
|
pcmk_shutdown = 1;
|
|
}
|
|
- if (pcmk_shutdown && !(node->details->running_rsc)) {
|
|
+ if (pcmk_shutdown)
|
|
+ {
|
|
pcmk_clean_shutdown = 1;
|
|
+ if (!(node->details->maintenance)) {
|
|
+ GListPtr iter;
|
|
+
|
|
+ for (iter = node->details->running_rsc;
|
|
+ iter != NULL; iter = iter->next) {
|
|
+ resource_t *rsc = (resource_t *) iter->data;
|
|
+
|
|
+
|
|
+ if (is_set(rsc->flags, pe_rsc_managed)) {
|
|
+ pcmk_clean_shutdown = 0;
|
|
+ crm_debug("not clean as %s managed and still running",
|
|
+ rsc->id);
|
|
+ break;
|
|
+ }
|
|
+ }
|
|
+ if (pcmk_clean_shutdown) {
|
|
+ crm_debug("pcmk_clean_shutdown because "
|
|
+ "all managed resources down");
|
|
+ }
|
|
+ } else {
|
|
+ crm_debug("pcmk_clean_shutdown because node is in maintenance");
|
|
+ }
|
|
}
|
|
notify_parent();
|
|
return;
|
|
--
|
|
1.8.3.1
|
|
|