nagios插件check_io_utils.py
博客专区 > jastme 的博客 > 博客详情
nagios插件check_io_utils.py
jastme 发表于4年前
nagios插件check_io_utils.py
  • 发表于 4年前
  • 阅读 389
  • 收藏 3
  • 点赞 0
  • 评论 2

【腾讯云】新注册用户域名抢购1元起>>>   

摘要: 利用iostat命令检查IO负载情况,主要监测utils这个参数,请先安装iostat
#!/usr/bin/python
# -*- coding:utf-8 -*-
from optparse import OptionParser
import subprocess
import sys
"""
    Nagios plugin to report the io utils by shell command iostat
    by jastme
"""
parser = OptionParser(usage="%prog -w <warning threshold> -c <critical threshold> [ -h ]",version="%prog ")

parser.add_option("-d", "--partion",action="store", type="string", dest="partion", help="choose the parion from the disk")

parser.add_option("-w", "--warning",action="store", type="string", dest="warn_threshold", help="Warning threshold in percentage")

parser.add_option("-c", "--critical",action="store", type="string", dest="crit_threshold", help="Critical threshold in percentage")

(options, args) = parser.parse_args()

def ioutil():
    utils=subprocess.Popen("iostat -x 1 2 -d %s | grep %s | awk 'NR==2{print $NF}'" %(options.partion,options.partion),shell=True,stdout=subprocess.PIPE)
    utils.wait()
    utilss=utils.communicate()[0][:-1]
    return eval(utilss)

def jastme():
    util=ioutil()
    if not options.crit_threshold:
        print "UNKNOWN: Missing critical threshold value."
        sys.exit(3)
    if not options.warn_threshold:
        print "UNKNOWN: Missing warning threshold value."
        sys.exit(3)
    if int(util) >= int(options.crit_threshold):
        print "Criticl, the partion %s IO_utils is nearly %s%% | io_utils=%s%%;%s;%s;0" %(options.partion,util,util,options.warn_threshold,options.crit_threshold)
        sys.exit(2)

    elif int(options.crit_threshold) > int(util) >= int(options.warn_threshold):
        print "Warning, the partion %s IO_utils is nearly %s%% | io_utils=%s%%;%s;%s;0" %(options.partion,util,util,options.warn_threshold,options.crit_threshold)
        sys.exit(1)

    else:
        print "OK, the partion %s IO_utils is nearly %s%% | io_utils=%s%%;%s;%s;0" %(options.partion,util,util,options.warn_threshold,options.crit_threshold)
        sys.exit(0)

if __name__ == '__main__':
    jastme()

  1. 修改了一个bug,iostat命令第一次取的值是系统从重启到现在的平均值,所以我们选择第2次的值,这样才准确。

  2. 修复一个bug.  用eval来返回值,然后用整数来比较,字符串比较有BUG


  • 打赏
  • 点赞
  • 收藏
  • 分享
共有 人打赏支持
粉丝 35
博文 122
码字总数 59358
评论 (2)
perofu
这里"iostat -x -d %s | grep %s | awk '{print $14}'"的$14,明显不对,换成$NF会比较好
jastme

引用来自“perofu”的评论

这里"iostat -x -d %s | grep %s | awk '{print $14}'"的$14,明显不对,换成$NF会比较好
root@app10C:/usr/local/nagios/etc/objects# iostat -x -d sda1 | grep sda1 | awk '{print $14}' 0.01 这是可以的 $NF也行,你这个科学点,谢谢哈。
×
jastme
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: