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

相关推荐
..空空的人8 小时前
C++基于protobuf实现仿RabbitMQ消息队列---项目设计
分布式·rabbitmq
小满、11 小时前
RabbitMQ:Fanout、Direct、Topic 交换机、队列声明与消息转换器
java·分布式·消息队列·rabbitmq·spring amqp
Wang's Blog11 小时前
RabbitMQ: 分布式事务的最终一致性解决方案
分布式·rabbitmq
云和数据.ChenGuang1 天前
OpenEuler系统下RabbitMQ安装与基础配置教程
服务器·分布式·rabbitmq·ruby·数据库运维工程师·运维教程
云和数据.ChenGuang1 天前
Deepseek适配场景:OpenEuler系统下RabbitMQ安装与基础配置教程
分布式·rabbitmq·ruby
Wang's Blog1 天前
RabbitMQ: 消息发送失败的重试机制设计与实现
分布式·rabbitmq
武子康1 天前
Java-206 RabbitMQ 发布订阅(fanout)Java 实战:推/拉模式、ACK 与绑定排错全梳理
java·分布式·消息队列·rabbitmq·rocketmq·java-rabbitmq·mq
武子康1 天前
Java-207 RabbitMQ Direct 交换器路由:RoutingKey 精确匹配、队列多绑定与日志分流实战
java·消息队列·rabbitmq·erlang·ruby·java-rabbitmq
sinat_363954232 天前
canal-deployer1.1.8 + mysql + rabbitmq消息队列
mysql·rabbitmq
武子康2 天前
Java-204 RabbitMQ Connection/Channel 工作流程:AMQP 发布消费、抓包帧结构与常见坑
java·分布式·消息队列·rabbitmq·ruby·java-activemq