summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthew Sackman <matthew@lshift.net>2010-04-12 17:26:43 +0100
committerMatthew Sackman <matthew@lshift.net>2010-04-12 17:26:43 +0100
commit385e0262c242ebaa165e337aeaf0d9ae48f3949d (patch)
treecf9d4cc447250eb5004bc011c297e4e7f4e6c867
parentd6032f95a30c11a763182ef5fbc6894cb974fe1f (diff)
downloadrabbitmq-server-385e0262c242ebaa165e337aeaf0d9ae48f3949d.tar.gz
Only export vars when they're needed, and don't do a full verify unless it's needed - the problem has been that the verify dies because eg the config file doesn't exist, but it doesn't exist because of, say, drbd not being primary+mounted...bug22500
-rwxr-xr-x[-rw-r--r--]packaging/common/rabbitmq-server.ocf37
1 files changed, 26 insertions, 11 deletions
diff --git a/packaging/common/rabbitmq-server.ocf b/packaging/common/rabbitmq-server.ocf
index a1689293..97c58ea2 100644..100755
--- a/packaging/common/rabbitmq-server.ocf
+++ b/packaging/common/rabbitmq-server.ocf
@@ -188,17 +188,19 @@ RABBITMQ_LOG_BASE=$OCF_RESKEY_log_base
RABBITMQ_MNESIA_BASE=$OCF_RESKEY_mnesia_base
RABBITMQ_SERVER_START_ARGS=$OCF_RESKEY_server_start_args
[ ! -z $RABBITMQ_NODENAME ] && NODENAME_ARG="-n $RABBITMQ_NODENAME"
-
[ ! -z $RABBITMQ_NODENAME ] && export RABBITMQ_NODENAME
-[ ! -z $RABBITMQ_NODE_IP_ADDRESS ] && export RABBITMQ_NODE_IP_ADDRESS
-[ ! -z $RABBITMQ_NODE_PORT ] && export RABBITMQ_NODE_PORT
-[ ! -z $RABBITMQ_CLUSTER_CONFIG_FILE ] && export RABBITMQ_CLUSTER_CONFIG_FILE
-[ ! -z $RABBITMQ_CONFIG_FILE ] && export RABBITMQ_CONFIG_FILE
-[ ! -z $RABBITMQ_LOG_BASE ] && export RABBITMQ_LOG_BASE
-[ ! -z $RABBITMQ_MNESIA_BASE ] && export RABBITMQ_MNESIA_BASE
-[ ! -z $RABBITMQ_SERVER_START_ARGS ] && export RABBITMQ_SERVER_START_ARGS
-
-rabbit_validate() {
+
+export_vars() {
+ [ ! -z $RABBITMQ_NODE_IP_ADDRESS ] && export RABBITMQ_NODE_IP_ADDRESS
+ [ ! -z $RABBITMQ_NODE_PORT ] && export RABBITMQ_NODE_PORT
+ [ ! -z $RABBITMQ_CLUSTER_CONFIG_FILE ] && export RABBITMQ_CLUSTER_CONFIG_FILE
+ [ ! -z $RABBITMQ_CONFIG_FILE ] && export RABBITMQ_CONFIG_FILE
+ [ ! -z $RABBITMQ_LOG_BASE ] && export RABBITMQ_LOG_BASE
+ [ ! -z $RABBITMQ_MNESIA_BASE ] && export RABBITMQ_MNESIA_BASE
+ [ ! -z $RABBITMQ_SERVER_START_ARGS ] && export RABBITMQ_SERVER_START_ARGS
+}
+
+rabbit_validate_partial() {
if [ ! -x $RABBITMQ_MULTI ]; then
ocf_log err "rabbitmq-server multi $RABBITMQ_MULTI does not exist or is not executable";
return $OCF_ERR_ARGS;
@@ -208,7 +210,9 @@ rabbit_validate() {
ocf_log err "rabbitmq-server ctl $RABBITMQ_CTL does not exist or is not executable";
return $OCF_ERR_ARGS;
fi
+}
+rabbit_validate_full() {
if [ ! -z $RABBITMQ_CLUSTER_CONFIG_FILE ] && [ ! -e $RABBITMQ_CLUSTER_CONFIG_FILE ]; then
ocf_log err "rabbitmq-server cluster_config_file $RABBITMQ_CLUSTER_CONFIG_FILE does not exist or is not a file";
return $OCF_ERR_ARGS;
@@ -229,6 +233,8 @@ rabbit_validate() {
return $OCF_ERR_ARGS;
fi
+ rabbit_validate_partial
+
return $OCF_SUCCESS
}
@@ -251,6 +257,15 @@ rabbit_status() {
rabbit_start() {
local rc
+
+ rabbit_validate_full
+ rc=$?
+ if [ "$rc" != $OCF_SUCCESS ]; then
+ return $rc
+ fi
+
+ export_vars
+
$RABBITMQ_MULTI start_all 1 > ${RABBITMQ_LOG_BASE}/startup_log 2> ${RABBITMQ_LOG_BASE}/startup_err &
rc=$?
@@ -323,7 +338,7 @@ case $__OCF_ACTION in
;;
esac
-rabbit_validate || exit
+rabbit_validate_partial || exit
case $__OCF_ACTION in
start)