zoukankan      html  css  js  c++  java
  • 11 Zabbix Item类型之Zabbix Calculated 计算型Item类型

    点击返回:自学Zabbix之路

    点击返回:自学Zabbix4.0之路

    点击返回:自学zabbix集锦

    11 Zabbix Item类型之Zabbix Calculated 计算型Item类型

    计算类型Item,可以通过计算其他的Item来获取数据 。注意是已定义过的key值。 在Item配置中,zabbix支持计算表达式。

    如这里我要创建一个计算linux服务器内存实际使用大小的监控项(计算方法为:vm.memory.size[total]-vm.memory.size[buffers]-vm.memory.size[cached]-vm.memory.size[free])。

    但zabbix默认的Items里并没有获取vm.memory.size[cached]这个key值。

    所以在查看Calculated类型的items时会出现Cannot evaluate function “last()”: item “coolnull:vm.memory.size[cached]” does not exist。

    要解决的话就需要自己再定义添加coolnull:vm.memory.size[cached]这个Items。

    以下这边以获取算linux服务器内存实际使用大小来举例:

    具体:

    1、在模板中或是主机中选择监控项—->选择Create item

    2、监控的名称和key按照其功能随便起一个名字(注:名字和key的名字一定要是英文格式的,包括你名字中包含的特殊字符)

          如:mem.realused,key的类型选择计算,这时会出现一个Formula,里面就是你的计算公式,

          如:(last(“vm.memory.size[total]”)-last(“vm.memory.size[buffers]”)-last(“vm.memory.size[cached]”)-last(“vm.memory.size[free]”))

          这个计算公式就是取各个key值的最后一次值做计算,注意公式中没有空格(经测试发现有时有空格之类的话提交的时候可能报错),计算的各个key都是同一类型的。

    3、其他的选项没有什么特别,参照公式中其中一个key值的设置选项设置即可。

    4、最后点保存提交,完成key的定义。

        这边发现如果用(last(“vm.memory.size[total]”)-last(“vm.memory.size[buffers]”)-last(“vm.memory.size[cached]”)-last(“vm.memory.size[free]”))来减的话,还需要再定义vm.memory.size[buffers]、vm.memory.size[cached]值。

        因此我直接使用(last(“vm.memory.size[total]“)-last(“vm.memory.size[available]“))来计算更方便,不需要再定义buffers、cached。
    z1

    备注:

    常用的计算类型key定义时用的有以下几种公式(注意一下公式在写入Formula时要加一个小括号):

    1、计算空闲磁盘空间的比例:
          100*last(“vfs.fs.size[/,free]”)/last(“vfs.fs.size[/,total]”)
    2、计算10分钟主机出流量的平均值:
          avg(“Zabbix Server:net.if.out[eth0,bytes]”,600)
    3、计算网卡总流量:
          last(“net.if.in[eth0,bytes]”)+last(“net.if.out[eth0,bytes]”)
    4、计算进流量占网卡总流量的比例:
          100*last(“net.if.in[eth0,bytes]”)/(last(“net.if.in[eth0,bytes]”)+last(“net.if.out[eth0,bytes]”))
    5、在计算项目中正确使用聚合条目,注意双引号如何被转义:
          last(“grpsum[”video”,”net.if.out[eth0,bytes]”,”last”,”0”]”)/last(“grpsum[”video”,”nginx_stat.sh[active]”,”last”,”0”]”)
    6、计算多台主机出流量的和:
          last(“192.168.1.100:net.if.out[eth0,bytes]”)+last(“192.168.1.200:net.if.out[eth0,bytes]”)+last(“192.168.1.110:net.if.out[eth0,bytes]”)
          这种计算是多台主机的,至于这个值放在哪个主机的监控项中都是一样的,只要是在此zabbix服务器端中。

  • 相关阅读:
    Python3-笔记-E-005-库-系统os
    Python3-笔记-E-004-库-日历calendar
    Python3-笔记-E-003-库-日期时间datatime
    Python3-笔记-E-002-库-Unix纪元时间戳time
    Python3-笔记-E-001-库-随机数random
    Python3-笔记-D-001-异常与断言
    Python3-笔记-C-007-函数-导入模块并调用
    【bzoj2199/Usaco2011 Jan】奶牛议会——2-sat
    【bzoj1578/Usaco2009 Feb】Stock Market 股票市场——完全背包
    【bzoj1741/Usaco2005 nov】Asteroids 穿越小行星群——最小割
  • 原文地址:https://www.cnblogs.com/yaoyaojcy/p/8208640.html
Copyright © 2011-2022 走看看