Blame SOURCES/lvmlockd-add-cmirrord-support.patch

b94b9d
From d4c9de6264251e4dbc91b64aaf7f500919d08d60 Mon Sep 17 00:00:00 2001
b94b9d
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
b94b9d
Date: Fri, 17 Aug 2018 12:48:46 +0200
b94b9d
Subject: [PATCH] lvmlockd: add cmirrord support
b94b9d
b94b9d
---
b94b9d
 heartbeat/lvmlockd | 53 ++++++++++++++++++++++++++++++++++++++++++----
b94b9d
 1 file changed, 49 insertions(+), 4 deletions(-)
b94b9d
b94b9d
diff --git a/heartbeat/lvmlockd b/heartbeat/lvmlockd
b94b9d
index 7fe73e364..57f7fdc76 100755
b94b9d
--- a/heartbeat/lvmlockd
b94b9d
+++ b/heartbeat/lvmlockd
b94b9d
@@ -59,6 +59,14 @@ For more information, refer to manpage lvmlockd.8.
b94b9d
 <shortdesc lang="en">This agent manages the lvmlockd daemon</shortdesc>
b94b9d
 
b94b9d
 <parameters>
b94b9d
+<parameter name="with_cmirrord" unique="0" required="0">
b94b9d
+<longdesc lang="en">
b94b9d
+Start with cmirrord (cluster mirror log daemon).
b94b9d
+</longdesc>
b94b9d
+<shortdesc lang="en">activate cmirrord</shortdesc>
b94b9d
+<content type="boolean" default="false" />
b94b9d
+</parameter>
b94b9d
+
b94b9d
 <parameter name="pidfile" unique="0">
b94b9d
 <longdesc lang="en">pid file</longdesc>
b94b9d
 <shortdesc lang="en">pid file</shortdesc>
b94b9d
@@ -102,6 +110,7 @@ END
b94b9d
 : ${OCF_RESKEY_pidfile:="/run/lvmlockd.pid"}
b94b9d
 
b94b9d
 LOCKD="lvmlockd"
b94b9d
+CMIRRORD="cmirrord"
b94b9d
 # 0.5s sleep each count
b94b9d
 TIMEOUT_COUNT=20
b94b9d
 
b94b9d
@@ -138,6 +147,21 @@ silent_status()
b94b9d
 
b94b9d
 	if [ -n "$pid" ] ; then
b94b9d
 		daemon_is_running "$pid"
b94b9d
+		rc=$?
b94b9d
+		mirror_rc=$rc
b94b9d
+
b94b9d
+		if ocf_is_true $OCF_RESKEY_with_cmirrord; then
b94b9d
+			pid=$(pgrep $CMIRRORD | head -n1)
b94b9d
+			daemon_is_running "$pid"
b94b9d
+			mirror_rc=$?
b94b9d
+		fi
b94b9d
+
b94b9d
+		# If these ever don't match, return error to force recovery
b94b9d
+		if [ $mirror_rc -ne $rc ]; then
b94b9d
+			return $OCF_ERR_GENERIC
b94b9d
+		fi
b94b9d
+
b94b9d
+		return $rc
b94b9d
 	else
b94b9d
 		# No pid file
b94b9d
 		false
b94b9d
@@ -199,6 +223,16 @@ lvmlockd_start() {
b94b9d
 		return $OCF_SUCCESS
b94b9d
 	fi
b94b9d
 
b94b9d
+	if ocf_is_true $OCF_RESKEY_with_cmirrord; then
b94b9d
+		ocf_log info "starting ${CMIRRORD}..."
b94b9d
+		$CMIRRORD
b94b9d
+		rc=$?
b94b9d
+		if [ $rc -ne $OCF_SUCCESS ] ; then
b94b9d
+			ocf_exit_reason "Failed to start ${CMIRRORD}, exit code: $rc"
b94b9d
+			return $OCF_ERR_GENERIC
b94b9d
+		fi
b94b9d
+	fi
b94b9d
+
b94b9d
 	if [ ! -z "$OCF_RESKEY_socket_path" ] ; then
b94b9d
 		extras="$extras -s ${OCF_RESKEY_socket_path}"
b94b9d
 	fi
b94b9d
@@ -252,10 +286,11 @@ wait_lockspaces_close()
b94b9d
 
b94b9d
 kill_stop()
b94b9d
 {
b94b9d
-	local pid=$1
b94b9d
+	local proc=$1
b94b9d
+	local pid=$2
b94b9d
 	local retries=0
b94b9d
 
b94b9d
-	ocf_log info "Killing ${LOCKD} (pid=$pid)"
b94b9d
+	ocf_log info "Killing $proc (pid=$pid)"
b94b9d
 	while
b94b9d
 		daemon_is_running $pid && [ $retries -lt "$TIMEOUT_COUNT" ]
b94b9d
 	do
b94b9d
@@ -292,9 +327,15 @@ lvmlockd_stop() {
b94b9d
 	wait_lockspaces_close
b94b9d
 
b94b9d
 	pid=$(get_pid)
b94b9d
-	kill_stop $pid
b94b9d
+	kill_stop $LOCKD $pid
b94b9d
+
b94b9d
+	if ocf_is_true $OCF_RESKEY_with_cmirrord; then
b94b9d
+		pid=$(pgrep $CMIRRORD)
b94b9d
+		kill_stop $CMIRRORD $pid
b94b9d
+	fi
b94b9d
+
b94b9d
 	if silent_status ; then
b94b9d
-		ocf_exit_reason "Failed to stop, ${LOCKD}[$pid] still running."
b94b9d
+		ocf_exit_reason "Failed to stop, ${LOCKD} or ${CMIRRORD} still running."
b94b9d
 		return $OCF_ERR_GENERIC
b94b9d
 	fi
b94b9d
 
b94b9d
@@ -317,6 +358,10 @@ lvmlockd_validate() {
b94b9d
 	check_binary pgrep
b94b9d
 	check_binary lvmlockctl
b94b9d
 
b94b9d
+	if ocf_is_true $OCF_RESKEY_with_cmirrord; then
b94b9d
+		check_binary $CMIRRORD
b94b9d
+	fi
b94b9d
+
b94b9d
 	return $OCF_SUCCESS
b94b9d
 }
b94b9d