栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

zabbix监控rabbitmq队列和进程--基于自动发现

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

zabbix监控rabbitmq队列和进程--基于自动发现

Zabbix5.0监控RabbitMQ队列和进程–基于自动发现
  1. Zabbix添加UserParameter,内容如下:

    UserParameter=rabbitmq[],/usr/bin/python /usr/local/sbin/rabbitmq.py $1
    UserParameter=messages[
    ],/etc/zabbix/scripts/rabbitmq/messages.sh $1

  2. 创建rabbitmq.py和messages.sh脚本,内容如下

#cat rabbitmq.py

#!/usr/bin/python
#coding:utf8
 
import requests
import sys
import json

class RabbitMQ:
 
 
    def __init__(self, user='zabbix', passwd='zabbix123', server_ip='172.21.2.5', server_port=15672, vhost="/"):
 
        self.user = user
        self.password = passwd
        self.server_ip = server_ip
        self.server_port = server_port
        self.vhost = vhost
 
 
    def GetQueues(self):
        # 连接并获取RabbitMQ数据,如果传getallname参数代表获取所有的队列名称,主要用于自动发现,如果不等于,那就是获取指定队列的数据
        if sys.argv[1] != "getallname":
            connections = requests.get("http://{0}:{1}/api/queues/{2}/{3}".format(self.server_ip, self.server_port, self.vhost, sys.argv[1]), auth=(self.user, self.password))
        else:
            connections = requests.get("http://{0}:{1}/api/queues".format(self.server_ip, self.server_port), auth=(self.user, self.password))
        connections = connections.json()
        return connections
 
 
    def GetAllQueuesName(self):
        # 获取所有队名称,格式化为Zabbix指定的格式,以便自动发现
        list1= []
        result = self.GetQueues()
        for n in range(len(result)):
            list1.append({"{#QUEUES_NAME}": result[n]["name"]})
        return list1
 
 
if __name__ == '__main__':
    mq = RabbitMQ()
    if sys.argv[1] != "getallname":
        result = mq.QueuesDataProcessing()
        print(result)
    else:
        result = mq.GetAllQueuesName()
        names = {"data": result}
        print(json.dumps(names))

#cat messages.sh

#!/bin/bash
curl -s  -u guest:guest  http://127.0.0.1:15672/api/queues/%2f/$1 |awk -F '"messages":' '{print $2}'|awk -F , '{print $1}'
#guest:guest是RabbitMQ的登陆账号密码,使用冒号分隔,只能在本地登陆,如不能登陆请按照第5步自行创建账号密码
  1. 重启zabbix客户端服务:systemctl restart zabbix-agent

  2. zabbix web界面导入Zabbix模板rabbitmq.xml并关联至指定的主机(模板名称RabbitMQ-Queues)
    #cat rabbitmq.xml


    5.0
    2022-03-14T05:47:06Z


    Templates




    RabbitMQ-Queues
    RabbitMQ-Queues


    Templates




    RabbitMQ Process


    RabbitMQ Queues




    RabbitMQ进程数量
    proc.num[beam.smp]


    RabbitMQ Process




    {last()}=0
    RabbitMQ进程挂了
    INFO






    RabbitMQ 队列监控
    rabbitmq[getallname]
    30s



    {#QUEUES_NAME}
    A





    RabbitMQ messages: {#QUEUES_NAME}
    messages[{#QUEUES_NAME}]
    30s


    RabbitMQ Queues






    RabbitMQ messages: {#QUEUES_NAME} 队列


    1
    1A7C11

    RabbitMQ-Queues
    messages[{#QUEUES_NAME}]









    队列
    1
    2


    0


    RabbitMQ messages: {#QUEUES_NAME} 队列
    RabbitMQ-Queues

    500
    100
    0
    1
    1
    1
    0
    0
    0
    0
    0


    2








    RabbitMQ进程数量图形


    1
    F63100

    RabbitMQ-Queues
    proc.num[beam.smp]





  3. 在rabbitmq主机添加可以远程连接的用户,并设置权限:
    #创建用户 rabbitmqctl add_user 用户名 密码
    rabbitmqctl add_user zabbix zabbix123
    #设置用户权限 rabbitmqctl set_permissions -p “/” 用户名 “.” “.” “."
    rabbitmqctl set_permissions -p “/” zabbix “.” “.” ".

    #设置用户角色 rabbitmqctl set_user_tags 用户名 administrator
    rabbitmqctl set_user_tags zabbix administrator

  4. Rabbitmq进程监控:
    ps -ef|grep rabbitmq找到进程名称,在模板中添加监控项,键值proc.num[beam.smp]

键值来源于键值选择中,将进程名添加即可,也可选择使用端口进行监控,自己选择。
添加触发器:

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/841425.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号