aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorolgeni <olgeni@FreeBSD.org>2015-02-01 00:19:46 +0800
committerolgeni <olgeni@FreeBSD.org>2015-02-01 00:19:46 +0800
commit5af19d2d215deeadae556181bee6547dc26f2eea (patch)
treef27db2dcbcaaa9f847a12cb7baf203599d6629e1 /net
parentc0a2e14f8a1412a79130c04f7fb6d0b8de2aec3c (diff)
downloadfreebsd-ports-gnome-5af19d2d215deeadae556181bee6547dc26f2eea.tar.gz
freebsd-ports-gnome-5af19d2d215deeadae556181bee6547dc26f2eea.tar.zst
freebsd-ports-gnome-5af19d2d215deeadae556181bee6547dc26f2eea.zip
Startup script fixes:
- Avoid race condition in startup. Use daemon(8) rather than "rabbitmqctl status" to safely retrieve the pid. - Make sure that the Erlang cookie permissions are correct before starting the RabbitMQ node (using rabbitmqctl as root could create a read-only cookie). - Make sure that the RabbitMQ application is actually running when rabbitmq_start is done. Remove the now useless "wait" command from extra_commands.
Diffstat (limited to 'net')
-rw-r--r--net/rabbitmq/Makefile1
-rw-r--r--net/rabbitmq/files/rabbitmq.in61
2 files changed, 44 insertions, 18 deletions
diff --git a/net/rabbitmq/Makefile b/net/rabbitmq/Makefile
index 7e0d9a1e0c47..1c3916be4772 100644
--- a/net/rabbitmq/Makefile
+++ b/net/rabbitmq/Makefile
@@ -3,6 +3,7 @@
PORTNAME= rabbitmq
PORTVERSION= 3.4.3
+PORTREVISION= 1
CATEGORIES= net
MASTER_SITES= http://www.rabbitmq.com/releases/rabbitmq-server/v${PORTVERSION}/
DISTNAME= ${PORTNAME}-server-${PORTVERSION}
diff --git a/net/rabbitmq/files/rabbitmq.in b/net/rabbitmq/files/rabbitmq.in
index 3169624ae88d..c576d62a845e 100644
--- a/net/rabbitmq/files/rabbitmq.in
+++ b/net/rabbitmq/files/rabbitmq.in
@@ -24,32 +24,57 @@ load_rc_config $name
rabbitmq_server="%%PREFIX%%/sbin/rabbitmq-server"
rabbitmq_ctl="%%PREFIX%%/sbin/rabbitmqctl"
-pidfile="/var/run/rabbitmq.pid"
+pidfile="/var/run/${name}.pid"
start_cmd="${name}_start"
-stop_cmd="env HOME=/var/db/rabbitmq su -m ${rabbitmq_user} -c 'sh -c \"${rabbitmq_ctl} stop\"'"
-stop_postcmd="wait_for_pids $rc_pid"
-rotate_logs_cmd="env HOME=/var/db/rabbitmq su -m ${rabbitmq_user} -c 'sh -c \"${rabbitmq_ctl} rotate_logs\"'"
-status_cmd="env HOME=/var/db/rabbitmq su -m ${rabbitmq_user} -c 'sh -c \"${rabbitmq_ctl} status\"'"
-extra_commands="rotate_logs status wait"
-wait_cmd=rabbitmq_wait
+stop_cmd="${name}_stop"
+rotate_logs_cmd="su -m ${rabbitmq_user} -c 'sh -c \"${rabbitmq_ctl} rotate_logs\"'"
+status_cmd="su -m ${rabbitmq_user} -c 'sh -c \"${rabbitmq_ctl} status\"'"
+extra_commands="rotate_logs status"
+
+export HOME=/var/db/${name}
+
+# Prevent conflicts with amqp_client and rabbit_common applications that
+# may be installed in ERL_LIBS.
+unset ERL_LIBS
rabbitmq_start()
{
- export HOME=/var/db/rabbitmq
- unset ERL_LIBS
- su -m ${rabbitmq_user} \
- -c "sh -c \"${rabbitmq_server} -detached\""
-# Grab pid (it appears that parsing the output of
-# status is the most reliable method)
- su -m ${rabbitmq_user} \
- -c "sh -c \"${rabbitmq_ctl} status\"" \
- | sed -n 's/[^p]*pid,\([0-9]*\)[^0-9]*/\1/p' > ${pidfile}
+ echo "Starting ${name}."
+
+ if [ -f ${HOME}/.erlang.cookie ]; then
+ chown ${rabbitmq_user}:${rabbitmq_user} ${HOME}/.erlang.cookie
+ fi
+
+ daemon -c -f -u ${rabbitmq_user} -p ${pidfile} ${rabbitmq_server}
+
+ local _attempt=10
+
+ while [ ${_attempt} -gt 0 ]; do
+ debug "Running: rabbitmqctl status (${_attempt})"
+ $rabbitmq_ctl status > /dev/null 2>&1 && break
+ _attempt=$((${_attempt} - 1))
+ sleep 1
+ done
+
+ if [ ${_attempt} -gt 0 ]; then
+ debug "Running: rabbitmqctl wait ${pidfile}"
+ $rabbitmq_ctl wait ${pidfile} >/dev/null 2>&1
+ fi
}
-rabbitmq_wait()
+rabbitmq_stop()
{
- $rabbitmq_ctl wait ${pidfile}
+ echo "Stopping ${name}."
+
+ debug "Running: ${rabbitmq_ctl} stop"
+
+ su -m ${rabbitmq_user} -c "sh -c \"${rabbitmq_ctl} stop\"" >/dev/null 2>&1
+
+ if [ -f ${pidfile} ]; then
+ read rc_pid < ${pidfile}
+ wait_for_pids $rc_pid
+ fi
}
run_rc_command "$1"