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