您好,登錄后才能下訂單哦!
一. 自定義nagios監(jiān)控腳本
1. 在客戶端上創(chuàng)建腳本/usr/local/nagios/libexec/check_disk.sh
vim /usr/local/nagios/libexec/check_disk.sh 寫入如下內(nèi)容:(client上)
#!/bin/bash
row=`df -h |wc -l` #輸出的總行數(shù)
for i in `seq 2 $row` #從第二行開始為真實(shí)的磁盤,因?yàn)榈谝恍袨樘ь^信息
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}'` #去掉%的使用率
p_p=`df -h -P|sed -n "$i"p|awk '{print $6}'` #掛載點(diǎn)
if [ "$u_per" -gt "97" ];then
echo -n "$p_p CRITICAL $u_per% $ava "
sta[$i]=2 #大于97,賦予返回值2并顯示一些信息
elif [ "$u_per" -gt "95" ];then
echo -n "$p_p WARNING! $u_per% $ava "
sta[$i]=1
else
echo -n "$p_p OK $u_per% $ava "
sta[$i]=0
fi
done
n=0
for j in `seq 2 $row` #找出最大值,
do
if [ "${sta[$j]}" -gt $n ];then
n=${sta[$j]}
fi
done
exit $n
##exit 2 表示這個(gè)程序退出后,它的返回值是2。
可以理解為這個(gè)程序死了,它的遺言是2,告訴別人自己是因?yàn)槭裁丛蛩赖舻?。這樣法醫(yī)(shell或它的父進(jìn)程)就可以知道原因,來判斷兇手(程序出錯)是誰,從而作進(jìn)一步的處理。
2. 保存后,修改該腳本的權(quán)限
chmod +x /usr/lib/nagios/plugins/check_disk.sh (client上)
3. 然后編輯/etc/nagios/nrpe.cfg文件
vim /etc/nagios/nrpe.cfg # 加入一行:(client上)
command[check_disk]=/usr/lib/nagios/plugins/check_disk.sh
保存,重啟nrpe服務(wù)
/etc/init.d/nrpe restart (client上)
4. 檢測剛才的腳本是否正常運(yùn)行的方法是,到server端執(zhí)行如下命令:
/usr/lib/nagios/plugins/check_nrpe -H 192.168.0.12 -c check_disk (server上)
如果正常的話,會輸出一行磁盤檢測的數(shù)據(jù),否則可能會報(bào)錯。
5. 到server上添加相應(yīng)的service
cd /etc/nagios/conf.d/
vim 192.168.0.12.cfg # 加入如下內(nèi)容:
define service{
use generic-service
host_name 192.168.0.12
service_description check_disk
check_command check_nrpe!check_disk
max_check_attempts 5
normal_check_interval 1
}
6. 重啟nagios服務(wù)
/etc/init.d/nagios restart (server上)
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。