cluster: STABLE3 - cman: make cman_tool leave remove work even when no services are running.
Christine Caulfield
chrissie@fedoraproject.org
Tue Jul 28 07:48:00 GMT 2009
Gitweb: http://git.fedorahosted.org/git/cluster.git?p=cluster.git;a=commitdiff;h=cacde1952b0bd5f913185527349f6c9ad4d2400b
Commit: cacde1952b0bd5f913185527349f6c9ad4d2400b
Parent: 5d55508f14db4363cd78759e6988a915fed1a417
Author: Christine Caulfield <ccaulfie@redhat.com>
AuthorDate: Tue Jul 28 08:46:36 2009 +0100
Committer: Christine Caulfield <ccaulfie@redhat.com>
CommitterDate: Tue Jul 28 08:46:36 2009 +0100
cman: make cman_tool leave remove work even when no services are running.
cman_tool leave takes a shortcut internally if no services are listening
for shutdown events. Unfortunately, a bug in this shortcut means that the
leave flags gets lost, so quorum is not adjusted downwards.
This patch fixes that shortcut. I should make it clear that 'leave remove'
works fine if any cluster services are running.
Signed-off-by: Christine Caulfield <ccaulfie@redhat.com>
---
cman/daemon/commands.c | 7 ++++++-
1 files changed, 6 insertions(+), 1 deletions(-)
diff --git a/cman/daemon/commands.c b/cman/daemon/commands.c
index 3607864..23ea810 100644
--- a/cman/daemon/commands.c
+++ b/cman/daemon/commands.c
@@ -1070,8 +1070,13 @@ static int do_cmd_try_shutdown(struct connection *con, char *cmdbuf)
/* If no-one is listening for events then we can just go down now */
if (shutdown_expected == 0) {
+ int leaveflags = CLUSTER_LEAVEFLAG_DOWN;
+
quit_threads = 1;
- send_leave(CLUSTER_LEAVEFLAG_DOWN);
+ if (shutdown_flags & SHUTDOWN_REMOVE)
+ leaveflags |= CLUSTER_LEAVEFLAG_REMOVED;
+
+ send_leave(leaveflags);
return 0;
}
else {
More information about the Cluster-cvs
mailing list