c++ 多key_详解Zabbix自定义Key监控Rabbitmq(监控特定队列)

概述

今天主要介绍一下zabbix怎么去自定义key来监控rabbitmq队列。


一、环境准备脚本

1、每秒钟插入一个观察队列情况(queues.py)

# -*- coding: utf-8 -*-import pikaimport timecredentials = pika.PlainCredentials('hwb', 'xxx')connection = pika.BlockingConnection(pika.ConnectionParameters('127.0.0.1',5672,'/',credentials))channel = connection.channel()queuename="hwb"channel.queue_declare(queue=queuename)i = 1while True:  channel.basic_publish(exchange='', routing_key=queuename, body='hwb body {0}'.format( i ))  print("insert hwb body success")  time.sleep(1)  i = i + 1
8152ac56015261e80214c6e031d2abca.png

2、消费者程序(rabbitconsumer.py)

# -*- coding: utf-8 -*-import pikacredentials = pika.PlainCredentials('hwb', 'xxx')connection = pika.BlockingConnection(pika.ConnectionParameters('127.0.0.1',5672,'/',credentials))channel = connection.channel()queuename="hwb"channel.queue_declare(queue=queuename)def callback(ch, method, properties, body):    print("Received %r" % body)channel.basic_consume(callback,queue=queuename,no_ack=True)print('Consume waiting for messages. To exit press CTRL+C')channel.start_consuming()
fdb8b9f2acb0af97ff68c9cd1364f51d.png

二、Rabbitmq监控脚本

77382fb8111c21e491eab56791a7c05c.png

1、Python获取队列信息(/etc/zabbix/zabbix_agentd.d/rabbitmqmonitor.py)

# -*- coding: utf-8 -*-try:  import jsonexcept:  import simplejson as jsonimport commands (status, output) = commands.getstatusoutput("""curl -s -u hwb:fxxx http://127.0.0.1:15672/api/queues""")outputjson = json.loads(output)for one in outputjson:  print(one['name'])  print(one['messages_ready'])  if(one.has_key('message_stats')):    if(one['message_stats'].has_key('deliver_get')):      print(one['message_stats']['deliver_get'])      continue  print(0)

分别输出:namemessages_readydeliver_get信息

e32bb7f5a464de0e1c9491f7ab440a8d.png

2、Shell监控脚本:(/etc/zabbix/zabbix_agentd.d/rabbitmq_check.sh)

#!/bin/bashqueuename=$1queuetype=$2result=$(python /etc/zabbix/zabbix_agentd.d/rabbitmqmonitor.py)case $2 in  "unread" )       echo "$result" |grep "^$queuename$" -A 2 |awk 'NR==2';;  "read" )       echo "$result" |grep "^$queuename$" -A 2 |awk 'NR==3';;  *)       echo "unsupport key";;esac

测试监控脚本

./rabbitmq_check.sh hwb read

./rabbitmq_check.sh hwb unread

f1523cdcbe322d750f96326da0341f41.png

3、自定义Key脚本(/etc/zabbix/zabbix_agentd.d/rabbitmq.conf)

 UserParameter=rabbitmq.status[*],sh /etc/zabbix/zabbix_agentd.d/rabbitmq_check.sh $1 $2

4、zabbix_get测试

 zabbix_get -s xxx -k rabbitmq.status[hwb,unread]
487d64b2d84d715624571931dd6d0bea.png

三、zabbix网页添加监控项

--未读队列名称:queue $1 $2键值:rabbitmq.status[hwb,unread]类型:数字单位:更新间隔:60s--每秒钟处理的队列数名称:queue $1 $2 persecond键值:rabbitmq.status[hwb,read]类型:浮点数单位:更新间隔:60s进程:每秒更改
40c4d2d16e1da85b35f5bd9f88d14d9e.png
8ec4c032366864d5ca01a66432d6f815.png
738f138ca439bc21e1f4ae69bcb5fd2d.png

四、zabbix网页添加触发器

--未读队列超过xxx告警   -> 监控业务有没有在正常处理名称:hwb queue unread>100严重性:严重表达式:{mq.jk:rabbitmq.status[hwb,unread].last()}>100--每秒钟处理的队列数超过xx告警  -> 监控业务的并发的能力名称:hwb queue read persecond > 200严重性:严重表达式:{mq.jk:rabbitmq.status[hwb,read].last()}>200
89a2bf48a6efd875bc7b9da7ea98f044.png
b3f0e07758a6f0bd6d3ca9f35524007b.png

五、测试

模拟产生队列达到100触发告警

告警邮件如下:

729591ad070ab84e11aa658970d7f697.png

修复邮件如下:

2a83767f10f20c75fa7be007cdb3d91d.png

觉得有用的朋友多帮忙转发哦!后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~

88ca793b261f81ed370270ff55d338cb.gif
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值