2018-04-18 08:35:57 +02:00
|
|
|
#!/bin/bash
|
|
|
|
#
|
2009-06-17 13:34:47 +02:00
|
|
|
# Plugin to monitor the queues of a virtual_host in RabbitMQ
|
|
|
|
#
|
|
|
|
# Usage: Link or copy into /etc/munin/node.d/
|
|
|
|
#
|
|
|
|
# Parameters
|
2018-05-04 11:59:18 +02:00
|
|
|
# env.url <url of management plugin>
|
2009-06-17 13:34:47 +02:00
|
|
|
# env.queue_warn <warning queuesize>
|
|
|
|
# env.queue_crit <critical queuesize>
|
|
|
|
#
|
|
|
|
# Magic markers (optional - only used by munin-config and some
|
|
|
|
# installation scripts):
|
|
|
|
#
|
|
|
|
#%# family=auto
|
|
|
|
#%# capabilities=autoconf
|
|
|
|
|
|
|
|
# If run with the "autoconf"-parameter, give our opinion on wether we
|
|
|
|
# should be run on this system or not. This is optinal, and only used by
|
|
|
|
# munin-config. In the case of this plugin, we should most probably
|
|
|
|
# always be included.
|
|
|
|
|
|
|
|
if [ "$1" = "autoconf" ]; then
|
|
|
|
echo yes
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
|
|
|
# If run with the "config"-parameter, give out information on how the
|
2018-04-18 08:35:57 +02:00
|
|
|
# graphs should look.
|
2009-06-17 13:34:47 +02:00
|
|
|
|
|
|
|
if [ "$1" = "config" ]; then
|
2018-05-04 11:59:18 +02:00
|
|
|
QUEUES=$(curl -sS $url/api/queues | jq -r '.[] | .name' | sed 's/[^a-z0-9]\+/_/g')
|
|
|
|
|
2018-04-18 08:35:57 +02:00
|
|
|
QUEUE_WARN=${queue_warn:-10000}
|
|
|
|
QUEUE_CRIT=${queue_crit:-20000}
|
2009-06-17 13:34:47 +02:00
|
|
|
|
|
|
|
# The host name this plugin is for. (Can be overridden to have
|
|
|
|
# one machine answer for several)
|
|
|
|
|
|
|
|
# The title of the graph
|
|
|
|
echo "graph_title RabbitMQ $VHOST Memory used by queue"
|
|
|
|
# Arguments to "rrdtool graph". In this case, tell it that the
|
|
|
|
# lower limit of the graph is '0', and that 1k=1000 (not 1024)
|
|
|
|
echo 'graph_args --base 1024 --vertical-label Bytes -l 0'
|
|
|
|
# The Y-axis label
|
|
|
|
echo 'graph_vlabel memory'
|
|
|
|
# We want Cur/Min/Avg/Max unscaled (i.e. 0.42 load instead of
|
|
|
|
# 420 milliload)
|
|
|
|
#echo 'graph_scale no'
|
2009-06-18 15:43:37 +02:00
|
|
|
echo 'graph_category RabbitMQ'
|
2009-06-17 13:34:47 +02:00
|
|
|
|
|
|
|
for queue in $QUEUES; do
|
|
|
|
echo "$queue.label $queue"
|
|
|
|
echo "$queue.warning $QUEUE_WARN"
|
|
|
|
echo "$queue.critical $QUEUE_CRIT"
|
|
|
|
echo "$queue.info Memory used by $queue"
|
|
|
|
done
|
|
|
|
|
|
|
|
echo 'graph_info Show memory usage by queue'
|
|
|
|
# Last, if run with the "config"-parameter, quit here (don't
|
|
|
|
# display any data)
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
|
|
|
# If not run with any parameters at all (or only unknown ones), do the
|
|
|
|
# real work - i.e. display the data. Almost always this will be
|
|
|
|
# "value" subfield for every data field.
|
|
|
|
|
2018-04-18 08:35:57 +02:00
|
|
|
IFS=$'\n'
|
2018-05-04 11:59:18 +02:00
|
|
|
for line in $(curl -sS $url/api/queues | jq -c -r '.[] | {name: .name, memory: .memory}'); do
|
|
|
|
echo -n "$line" | jq -j '.name' | sed 's/[^a-z0-9]\+/_/g'
|
2018-04-18 08:35:57 +02:00
|
|
|
echo -n ".used.value "
|
2018-05-04 11:59:18 +02:00
|
|
|
echo -n "$line" | jq -j '.memory'
|
2018-04-18 08:35:57 +02:00
|
|
|
echo ""
|
|
|
|
done
|
|
|
|
IFS=$' \t\n'
|