zoukankan      html  css  js  c++  java
  • zabbix磁盘的自动发现与磁盘指标监控

    由于最近项目上需要对服务器监控进行规范化监控,再磁盘这块有几种方式

    1.如果每台设备的磁盘是一样的 比如都有vda,vdb两块磁盘那么可以采用

      1.1 每台客户端写脚本,服务端每台设备去加上监控项(------最次的手段-------------)

      1.2 客户端批量部署脚本,服务端直接把监控项部署到模板里面去。这样所有使用了模板的设备都可以加上这个监控项目了  但是必须注意,这样必须是所有设备磁盘都一样的情况

    2.如果每台设备的磁盘数目不一样,就只能采用客户端定义脚本,服务端单独针对每台设备添加独特的监控项

    3.利用python 脚本添加(平庸选择)

    4.上面的方法都是不是那么智能化,其实zabbix为我们提供了一个自动发现规则(注意 不是设备的自动发现 ),再模板的下方自动发现规则:就是下图这个东西

    他能实现什么功能呢? 他提供一套发现与处理机制!!!!那么真多磁盘呢?他可以实现自动发现主机上面的磁盘,并且为每个磁盘加上监控项目,后续还可以自动为每个监控加图形,告警等等 后话了。 那么怎么实现呢?就是zabbix提供的机制 +++ 个人的脚本 以下慢慢道来!!

    一:为了实现我们的功能,我们第一步就是实现磁盘发现,也就是自动发现我们设备上又那么些磁盘(注意以下的操作都是以模板为单位的)

     找到这个自动发现规则,点击右边的创建自动发现规则如下:

    我们的名字可以随便起,这里类型我们是zabbix客户端 键值是什么呢?就是给后台传递的参数:完成的功能就是发现主机,这里得到的结果是个json格式的字符串。好了既然把这个参数io.scandisk传递到客户端了,那么我们的客户端怎么配置,完成什么功能呢?

    我们直接看zabbix-agent的配置文件

    这里面scandisk就是对应页面配置的关键字 [*]里面就是传递的参数,由于页面没有传递,那么这里就没有,后面的$1企业也没用(保留是因为大家都这么写。。。具体为啥我也不清楚)如果需要传递参数我们可以这么写

    页面io.scandisk[1,2] 那么这里的1就是客户端配置文件里面的$1了,同理2就是$2了.

    好了,我们看到客户端得到这个键后会执行一个python脚本,python脚本内容如下:

    import subprocess
    import json
    args="cat /proc/diskstats|awk '{print $3}'|grep -E '^[a-z]+$'|sort|uniq 2>/dev/null"
    t=subprocess.Popen(args,shell=True,stdout=subprocess.PIPE).communicate()[0]
    disks=[]
    for disk in t.split('
    '):
            if len(disk) != 0:
                    disks.append({'{#DISK_NAME}':disk})
    print json.dumps({'data':disks},indent=4,separators=(',',':'))
    

      我们执行下脚本得到结果如下:

    和上文我们提到的一样返回的是一个json字符串!

    每台设备不一样。得到的结果也不一样,获取的是本机上的物理磁盘的名称

    好了,既然已经获取到了磁盘的名字,我们接下来就会对每个磁盘的性能进行监控了,监控肯定也是在客户端实现。首先我们把需要的内容输出到一个文件里面

    nohup iostat -m -x -d 30 > /tmp/iostat_output &

    然后再配置文件里面田间配置

    UserParameter=io.rps[*],/usr/bin/tail /tmp/iostat_output |grep "$1"|tail -1|awk '{print $$4}'
    UserParameter=io.wps[*],/usr/bin/tail /tmp/iostat_output |grep "$1" |tail -1|awk '{print $$5}'
    UserParameter=io.rMBps[*],/usr/bin/tail /tmp/iostat_output |grep "$1" |tail -1|awk '{print $$6}'
    UserParameter=io.wMBps[*],/usr/bin/tail /tmp/iostat_output |grep "$1" |tail -1|awk '{print $$7}'
    UserParameter=io.avgrq-sz[*],/usr/bin/tail /tmp/iostat_output |grep "$1" |tail -1|awk '{print $$8}'
    UserParameter=io.avgqu-sz[*],/usr/bin/tail /tmp/iostat_output |grep "$1" |tail -1|awk '{print $$9}'
    UserParameter=io.await[*],/usr/bin/tail /tmp/iostat_output |grep "$1" |tail -1|awk '{print $$10}'
    UserParameter=io.svctm[*],/usr/bin/tail /tmp/iostat_output |grep "$1" |tail -1|awk '{print $$11}'
    UserParameter=io.util[*],/usr/bin/tail /tmp/iostat_output |grep "$1" |tail -1|awk '{print $$12}'

    这里面我们可以看到每行都有一个$1 那么这个$1是怎么来的呢?其实他就是代表磁盘的名字 所以我们页面就需要配置监控项,把参数(磁盘满传递过来)

    我们回到页面继续配置

    点击创建监控项原型以io.avgqu-sz为例

    名字随便取最好加上$1这里的$1其实就是键值里面的io.avgqu-sz[{#DISK_NAME}]里面的#DISK_NAME 我们前面用自动发现不是发现了自己的磁盘么? 比如sdb和sda,zabbix会把这两个磁盘循环传递到这里来作为DISK_NAME,那么你一定也想到了。客户端里面的$1其实也是这个参数咯  ------------至于怎么实现,只有看源码咯。。不必纠结  应用集我们新建一个DISK。然后点击更新完成

    至此我们只需等待然后到页面去看数据就可以了。就完成了磁盘的自动发现以及指定项的监控。。后面的图形,如果你理解了这里就是小菜一碟了。


    我们重新再来理一遍   服务端配置 自动发现规则发现磁盘------>客户端修改配置文件以及自定义脚本实现(返回json的格式)

    服务端找到磁盘以后对把每个磁盘的名称作为参数传递给监控项,监控项根据客户端的配置文件以及脚本实现对应的数据返回。

    另外需要注意的是 在监控项里面 有 print $$4 这种写法。 需要注意的是 因为在zabbix里面$1..$N 其实是关键字代表的是前端传递过来的参数,所以自己的$1需要在前面加上一个$也是就$$1来区别!!!这个东西当时也是疑惑了很久

     

  • 相关阅读:
    2016.2.17文件夹选择框及文件选择框
    2016.1.22 利用LINQ实现DataSet内多张DataTable关联查询操作(目前未发现太大价值)
    2016.1.23 通过cmd在程序中执行sql脚本
    2016.1.19 DEV Express控件GirdControl使用
    2016.1.1 VS中宏的使用技巧点滴
    2015.12.24(圣诞节) 解决Oralce数据库将具有相同属性的多行合并为一行的简单方法多年想要wmsys.wm_concat
    2015.12.12 DataGridveiw中添加checkbox列
    2015.11.3 RichBox改变若干文本颜色
    2015.12.10 如何将一个工程彻底改名
    2015.9.2 文本框中获取当前位置的所在行和列
  • 原文地址:https://www.cnblogs.com/ZFBG/p/10194768.html
Copyright © 2011-2022 走看看