Zabbix监控 RabbitMQ 指定消息队列名称(pull_alarms )的消费者

✅ 1. 编写 RabbitMQ 队列监控脚本

创建脚本文件 /usr/local/bin/zbx_rabbitmq_metric.sh 并写入以下内容:

复制代码
#!/bin/bash
# /usr/local/bin/zbx_rabbitmq_metric.sh

QUEUE=$1
METRIC=$2
USER=$3
PASS=$4

if [[ -z "$QUEUE" || -z "$METRIC" || -z "$USER" || -z "$PASS" ]]; then
  echo "Missing arguments"
  exit 1
fi

# URL encode queue name
ENCODED_QUEUE=$(printf %s "$QUEUE" | jq -s -R -r @uri)

# 调用 RabbitMQ API(注意修改虚拟主机名 prod_kac_saas)
API_URL="http://localhost:15672/api/queues/prod_kac_saas/${ENCODED_QUEUE}"
RESPONSE=$(curl -s -u "$USER:$PASS" "$API_URL")

# 提取目标字段值
VALUE=$(echo "$RESPONSE" | jq -r ".$METRIC")

# 处理空值
if [[ "$VALUE" == "null" || -z "$VALUE" ]]; then
  echo 0
else
  echo "$VALUE"
fi

设置执行权限:

复制代码
chmod +x /usr/local/bin/zbx_rabbitmq_metric.sh

✅ 2. Zabbix Agent 配置

编辑 /etc/zabbix/zabbix_agentd.d/rabbitmq.conf 文件,加入以下内容:

复制代码
UserParameter=rabbitmq.queue.metric[*],/usr/local/bin/zbx_rabbitmq_metric.sh "$1" "$2" "$3" "$4"

然后重启 Zabbix Agent:

复制代码
systemctl restart zabbix-agent

✅ 3. Zabbix Web 配置

✅ 添加宏(Template 或 Host 层级)

前往 Zabbix Web → Configuration → Templates (或 Hosts),找到应用的模板或主机,添加以下宏:

宏名称 宏值
{$RABBITMQ.API.USER} RabbitMQ 的用户名
{$RABBITMQ.API.PASSWORD} RabbitMQ 的密码

✅ 添加监控项(Item)

  • 名称pull_alarms: Consumers

  • 键值

    复制代码
    rabbitmq.queue.metric[pull_alarms,consumers,{$RABBITMQ.API.USER},{$RABBITMQ.API.PASSWORD}]
  • 类型:Zabbix agent

  • 数据类型:Numeric (unsigned)

  • 更新间隔:30s 或其他合适间隔

  • 单位:个


✅ 可选:添加图形 (Graph)

你可以为该监控项添加图形,例如:

  • 图形名称pull_alarms: Number of consumers

  • Y轴单位:Consumers

  • 添加 Item:上面创建的监控项


✅ 4. 验证监控效果

执行测试命令检查是否返回消费者数量:

复制代码
zabbix_agentd -t 'rabbitmq.queue.metric[pull_alarms,consumers,admin,password]'

若输出非 0,表示监控脚本正常工作,Zabbix 也可采集到该指标。


📌 总结

  • 监控方式:Zabbix agent + RabbitMQ HTTP API。

  • 核心指标:队列 pull_alarms 的消费者数量。

  • 扩展:只需替换 pull_alarms 为其他队列名,即可通用化监控。

相关推荐
forestqq4 小时前
zabbix平台无法删除已停用主机的处理案例
运维·服务器·zabbix
null不是我干的5 小时前
微服务消息队列之RabbitMQ,深入了解
微服务·rabbitmq·java-rabbitmq
dessler9 小时前
RabbitMQ-镜像队列(Mirrored Queues)
linux·运维·rabbitmq
都叫我大帅哥10 小时前
RabbitMQ消息模式大揭秘:从入门到精通,一篇搞定!
java·rabbitmq
九伯都17 小时前
rabbitmq的安装和使用-windows版本
windows·分布式·rabbitmq
_oP_i17 小时前
RabbitMQ 队列配置设置 RabbitMQ 消息监听器的并发消费者数量java
java·rabbitmq·java-rabbitmq
首席令狐冲1 天前
RabbitMQ安装与介绍
分布式·rabbitmq·ruby
在未来等你1 天前
RabbitMQ面试精讲 Day 6:消息确认与事务机制
消息队列·rabbitmq·面试题·事务机制·分布式系统·消息确认
菜萝卜子1 天前
【Zabbix】Ansible批量部署ZabbixAgent
ansible·zabbix
周某某~1 天前
Rabbit MQ的消息模式-Java原生代码
java·分布式·rabbitmq