nagios监控iostat[技术]

网上NetSeek写了一篇文章就是用nagios监控iostat的,但他使用的都是源码包编译的,具体可以参考他的这篇文章http://bbs.linuxtone.org/thread-2289-1-1.html

但编译的方式对于多机部署上来讲可能会有些不太方便,所以蚊子我在网上查了一下要想让nagios监控iostat需要的rpm包

蚊子我的环境都是centos5,所以我下载的包都是rhel5的,有需要其他环境的,我会在下面把下载地址给出,各位自己去找适合自己的。

http://packages.sw.be/perl-Nagios-Plugin/perl-Nagios-Plugin-0.33-1.el5.rf.noarch.rpm
http://dag.wieers.com/rpm/packages/perl-Class-Accessor/perl-Class-Accessor-0.31-1.el5.rf.noarch.rpm
http://dag.wieers.com/rpm/packages/perl-Config-Tiny/perl-Config-Tiny-2.12-1.el5.rf.noarch.rpm
http://dag.wieers.com/rpm/packages/perl-Math-Calc-Units/perl-Math-Calc-Units-1.06-1.el5.rf.noarch.rpm
http://dag.wieers.com/rpm/packages/perl-Params-Validate/perl-Params-Validate-0.89-1.el5.rf.i386.rpm(32位版)
http://dag.wieers.com/rpm/packages/perl-Params-Validate/perl-Params-Validate-0.89-1.el5.rf.x86_64.rpm(64位版)
http://dag.wieers.com/rpm/packages/perl-Regexp-Common/perl-Regexp-Common-2.120-1.2.el5.rf.noarch.rpm

如果需要其他环境的包可以到以下地址下载

perl-nagios-plugin                    http://packages.sw.be/perl-Nagios-Plugin/
perl-class-accessor                 http://dag.wieers.com/rpm/packages/perl-Class-Accessor/
perl-config-tiny                           http://dag.wieers.com/rpm/packages/perl-Config-Tiny/
perl-math-calc-units                 http://dag.wieers.com/rpm/packages/perl-Math-Calc-Units/
perl-params-validate                http://dag.wieers.com/rpm/packages/perl-Params-Validate/
perl-regexp-common                http://dag.wieers.com/rpm/packages/perl-Regexp-Common/

接下来出场的就是我们的主角,监控脚本check_iostat,下载地址是

http://www.ofn.dk/files/software/check_iostat

将此文件下载到/path/to/nagios/libexec下,并赋予执行权限,然后可以通过执行此脚本查看返回值

# ./check_iostat
IOSTAT OK – user 0.50 nice 0.01 sys 1.47 iowait 2.09 idle 0.00  | iowait=2.09%;; idle=0.00%;; user=0.50%;; nice=0.01%;; sys=1.47%;;

当然iostat命令是需要的,如果执行中出现以下错误

# ./check_iostat
Can’t exec “iostat”: No such file or directory at ./check_iostat line 69.
IOSTAT UNKNOWN – Error executing iostat command

请查看sysstat包是否安装

对于批量安装我的想法是,首先将check_iostat和所有rpm包打包上传到所有的服务器,这里最好的选择是rsync的方式,如果都是32位或都是64位的系统,可以直接执行rpm –ivh perl-*就行了,如果是两者都有,我这里写了一个脚本用来判断操作系统,脚本如下

#!/bin/bash
banner=$(uname -i)
cd ~/src
rpm -ivh perl-Class-Accessor-0.31-1.el5.rf.noarch.rpm
rpm -ivh perl-Config-Tiny-2.12-1.el5.rf.noarch.rpm
rpm -ivh perl-Math-Calc-Units-1.06-1.el5.rf.noarch.rpm
rpm -ivh perl-Regexp-Common-2.120-1.2.el5.rf.noarch.rpm
case $banner in
i386)
rpm -ivh perl-Params-Validate-0.89-1.el5.rf.i386.rpm
;;
x86_64)
rpm -ivh perl-Params-Validate-0.89-1.el5.rf.x86_64.rpm
;;
*)
exit 1
;;
esac

rpm -ivh perl-Nagios-Plugin-0.33-1.el5.rf.noarch.rpm

这里把所有包,包含32位和64位的同时放到src目录下。

nagios-plugin和nrpe快速部署办法[原创]

最近公司的监控服务器安装的差不多了,接下来的任务就是被监控机上的nagios-plugin和nrpe的安装了,200多台机器真要一台一台手工安装,就真的会死人了,在今天下午找到了个快速部署的办法,特把此方法与给位分享一下,高手可以忽略了。

1,先在任意一台被监控机上安装nagios-plugin和nrpe,安装目录同为/usr/local/nagios或者按各自的实际要求来定,同时这台被监控机上最好是带有mysql,这样监控mysql的脚本就会被编译进去了,这两个软件同在一个目录的一个好处就是两个软件之间可以互相使用对方libexec目录下的程序。

2,修改/etc/xinetd.d/nrpe文件,这里只需要注释掉only_from那行就行了,当然如果你的监控机只有一台,你可以考虑把那个ip改成你监控机的ip

3,修改nrpe.cfg文件,因为我希望我的每台被监控的服务器的监听ip都bind到本机的内网网卡的ip上,所以我会把#server_address=127.0.0.1这行的注释去掉。

修改
command[check_hda1]=/usr/local/nagios/libexec/check_disk -w 20% -c 10% -p /dev/hda1

command[check_disk]=/usr/local/nagios/libexec/check_disk -w 20% -c 10%

而且可以在这里把你需要监控资源都写上。

4,打包处理,接下来的任务就是把nagios目录和xinetd.d目录下的nrpe文件打到一个包中当做分发的基础包

tar zcvf nagios.tar.gz /usr/local/nagios /etc/xinetd.d/nrpe

5,将包分发,并执行配置脚本。将打好的tar包和下面的脚本分发到将要部署的服务器上,并执行脚本,这样被监控服务器就配置完毕了,当然以下脚本可以根据自己的实际应用进行调整。至于分发方法按各位习惯用的就行了,通常常使用的就是rsync,scp,cfengine统一配置等等

下面对上面的脚本做个解释

3行是创建用户
4行是将nagios包加压缩到相应的位置,nagios到/usr/local/nagios,nrpe到/etc/xinetd.d下
6行获取内网网卡的ip
7行首先将server_address的ip改成本机内网ip的地址,同时把allowed_hosts的地址在原有的基础上添加了本机内网的地址和监控机的地址
8行设置nrpe启动监听的ip地址
9行添加nrpe的服务端口
10行重启xinetd服务,也就是启动nrpe的进程

将此脚本存到其他的被监控机,并把那个nagios包也放上去,然后执行脚本,等数秒钟后使用netstat命令查看端口

# netstat -ln
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address               Foreign Address             State
tcp        0      192.168.202.129:5666                0.0.0.0:*                   LISTEN
tcp        0      0 0.0.0.0:111                 0.0.0.0:*                   LISTEN
tcp        0      0 :::22                       :::*                        LISTEN
udp        0      0 0.0.0.0:111                 0.0.0.0:*

首先在本机测试nrpe,执行下面的命令

[root@linux02 tmp]# /usr/local/nagios/libexec/check_nrpe -H 192.168.202.129
返回如下结果
NRPE v2.12

再来从监控机上执行命令查看被监控机的nrpe

[root@linux01 ~]# /usr/local/nagios/libexec/check_nrpe -H 192.168.202.129
返回结果如下
NRPE v2.12

由此可以看到,这样的部署方便快捷,到此,快速部署nagios-plugin和nrpe就写完了,当然以上部署还很基础,很多监控脚本都没有集成进去,还需要很多的完善,但此篇文章仅仅是给大家一个引子。

另外。如果有些人不喜欢使用xinetd来启动nrpe的话,可以讲上面的脚本稍微的改改,将

/usr/local/nagios/bin/nrpe -c /usr/local/nagios/etc/nrpe.cfg –d

这条命令添加到rc.local里,这样也可以启动nrpe