在客户端以下位置编辑配置文件
1、vim /usr/lib64/nagios/plugins/check_disk.sh
#!/bin/bash
#!/bin/bash
row=`df -h |wc -l`
for i in `seq 2 $row` #从df -h的第二行开始
do
ava=`df -h |sed -n "$i"p|awk '{print $4}'` #打印第四行也就是剩余多少
u_per=`df -h |sed -n "$i"p|sed -n "s/\%//"p|awk '{print $5}'` #使用多少百分比,sed -n 跟行数
p_p=`df -h -P|sed -n "$i"p|awk '{print $6}'` #剩余多少百分比
if [ "$u_per" -gt "97" ];then
echo -n "$p_p CRITICAL $u_per% $ava" #echo -n让输出的内容不用换行
sta[$i]=2 #表示数组,nagios里面2则会报 CRITICAL
elif [ "$u_per" -gt "95" ];then
echo -n "$p_p WARNING! $u_per% $ava" #echo -n可以让输出的内容不换行
sta[$i]=1 #表示数组,1会报WARNING
else
echo -n "$p_p OK $u_per% $ava "
sta[$i]=0 #表示数组,0会报ok
fi
done
n=0
for j in `seq 2 $row`
do
if [ "${sta[$j]}" -gt $n ];then
n=${sta[$j]}
fi
done
exit $n
2. 保存后,修改该脚本的权限
chmod +x /usr/lib64/nagios/plugins/check_disk.sh (client上)
3. 然后编辑/etc/nagios/nrpe.cfg文件
vim /etc/nagios/nrpe.cfg # 加入一行:(client上)
command[check_disk]=/usr/lib64/nagios/plugins/check_disk.sh
保存,重启nrpe服务
/etc/init.d/nrpe restart (client上)
4. 检测刚才的脚本是否正常运行的方法是,到server端执行如下命令:
/usr/lib64/nagios/plugins/check_nrpe -H 10.10.13.247 -c check_disk #(server上)
#如果正常的话,会输出一行磁盘检测的数据,否则可能会报错。
5. 到server上添加相应的host和service
cd /etc/nagios/conf.d/
vim 10.10.13.247.cfg # 加入如下内容:
define host{
use linux-server
host_name 10.10.13.247
alias 13.247
address 10.10.13.247
}
define service{
use generic-service
host_name 10.10.13.247
service_description check_disk
check_command check_nrpe!check_disk
max_check_attempts 5
normal_check_interval 1
}
6、定义command
vim /etc/nagios/objects/commands.cfg
增加:
define command{
command_name check_nrpe
command_line $USER1$/check_nrpe -H $HOSTADDRESS$ -c $ARG1$
}
7. 重启nagios服务
/etc/init.d/nagios restart (server上)
8、使用浏览器访问发现已经添加一项监控服务
转载于:https://blog.51cto.com/riverxyz/1793144