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 为其他队列名,即可通用化监控。

相关推荐
Msshu12317 小时前
Type-C 多协议快充诱骗电压芯片XSP28 芯片脚耐压高达21V 电路简单 性价比高
mongodb·zookeeper·rabbitmq·flume·memcache
Java 码农18 小时前
RabbitMQ集群部署方案及配置指南03
java·python·rabbitmq
独自破碎E1 天前
RabbitMQ中的Prefetch参数
分布式·rabbitmq
爱琴孩1 天前
RabbitMQ 消息消费模式深度解析
rabbitmq·消息重复消费
利刃大大1 天前
【RabbitMQ】Simple模式 && 工作队列 && 发布/订阅模式 && 路由模式 && 通配符模式 && RPC模式 && 发布确认机制
rpc·消息队列·rabbitmq·队列
南行*1 天前
MSF安全开发
安全·网络安全·系统安全·ruby
maozexijr2 天前
Rabbit MQ中@Exchange(durable = “true“) 和 @Queue(durable = “true“) 有什么区别
开发语言·后端·ruby
J_liaty2 天前
RabbitMQ面试题终极指南
开发语言·后端·面试·rabbitmq
maozexijr2 天前
RabbitMQ Exchange Headers类型存在的意义?
分布式·rabbitmq
独自破碎E2 天前
RabbitMQ的消息确认机制是怎么工作的?
分布式·rabbitmq