【8】nagios从零学习使用
有些要监控服务,网上可能并没有现成的插件,需要自己写,求人并不一定能求得到,那么就自己写。nagios的插件支持多种脚本或编译后的程序。
插件应要有下面二点:
A、插件需要一个返回值
0:表示状态OK
1:表示状态warn
2:表示状态crit
3:表示状态未知
B、插件向标准设备输出一行字
下面是一个查看linux free内存的shell脚本(模仿版,开始写需要网上下一些插件脚本模仿一下):
#!/bin/bash
#
# Plugin to check free mem space
# by onepc (153785587@qq.com)
# command_line $USER1$/check_freemem -H $HOSTNAME$ -p $ARG1$ -C "$ARG2$ $ARG3$ $ARG4$ $ARG5$ $ARG6$"
# Command-Line for service (example)
#
#
##########################################################
#定义 nagios返回的状态变量
STATE_OK=0
STATE_WARNING=1
STATE_CRITICAL=2
STATE_UNKNOWN=3
if [[ $# -lt 4 ]]
then
echo ""
echo "Wrong Syntax: `basename $0` $*"
echo ""
echo "Usage: $USAGE"
echo ""
exit 0
fi
while [[ $# -gt 0 ]]
do
case "$1" in
-w|--warning)
shift
warn=$1
;;
-c|--critical)
shift
crit=$1
;;
esac
shift
done
total_mem=`free | grep Mem | awk '{print $2}'`
free_mem=`free | grep Mem | awk '{print $4}'`
if [ "$warn" -lt "$crit" -o "$warn" -eq "$crit" ]; then
echo "Unknown: must be larger than "
exit $STATE_UNKNOWN
fi
use=`echo $(( ($free_mem * 100) / $total_mem ))`
if [ "$use" -gt "$warn" -o "$use" -eq "$warn" ]; then
echo "OK:$use% free memory"
exit $STATE_OK
elif [ "$use" -lt "$warn" -a "$use" -gt "$crit" ]; then
echo "Warning:$use% free memory"
exit $STATE_WARNING
elif [ "$use" -eq "$crit" -o "$use" -lt "$crit" ]; then
echo "Critical:$use% free memory"
exit $STATE_CRITICAL
else
echo "Unknown"
exit $STATE_UNKNOWN
fi
把脚本复制到/usr/local/nagios/libexec 目录下,并更改脚本的所有组及加上执行权限。
chown nagios:nagios check_freemem.sh
chmod a+x check_freemem.sh
在nrpe.cfg添加以下命令:
command=/usr/local/nagios/libexec/check_freemem.sh -w $ARG1$ -c $ARG2$
在centron添加服务关系到主机
http://s3.运维网.com/wyfs02/M02/23/AF/wKioL1M-X_LTfSyWAANSeH7a6Mk330.jpg
http://s3.运维网.com/wyfs02/M01/23/AE/wKiom1M-YBuBTvDPAAGCltVrwyc665.jpg
页:
[1]