Как я могу проверить точный объем оставшегося места (МБ или ГБ) в Nagios, используя команду check_nt вместо процентного значения?
В настоящее время я использую эту команду:
check_command check_nt!USEDDISKSPACE!-l c -w 90 -c 95
но это проверка процентного значения используемого дискового пространства, и я хочу получить уведомление, когда у меня останется точное количество ГБ на каком-то диске (например, предупреждение, когда останется 10 ГБ и критическое, когда останется только 5 ГБ).
Спасибо
check_nt!USEDDISKSPACE
возвращает размер и процент использования диска. Но пороги процентные.
Если вы хотите получать оповещения в зависимости от размера, вы можете написать сценарий оболочки оболочки для check_nt
команда, например check_disk_by_size
:
#!/bin/bash
FREESPACE=`/usr/local/nagios/libexec/check_nt -H $2 -p 12489 -s pa$$word \
-v USEDDISKSPACE -l $4 | awk -F"- " '{ print $4 }' | awk -F "|" '{ print $1 }'`
SIZE=`echo $FREESPACE | awk '{ print $2 }'`
UNIT=`echo $FREESPACE | awk '{ print $3 }'`
if [ $UNIT == "Gb" ]; then
SIZE=`echo $SIZE \* 1024 | bc`
fi
if [ `echo "$SIZE >= $6" | bc` -eq 1 ]; then
echo "$4:\_Drive_Space OK - $FREESPACE"
exit 0
elif [ `echo "$SIZE < $6" | bc` -eq 1 -a `echo "$SIZE > $8" | bc` -eq 1 ]; then
echo "$4:\_Drive_Space WARNING - $FREESPACE"
exit 1
elif [ `echo "$SIZE <= $8" | bc` -eq 1 ]; then
echo "$4:\_Drive_Space CRITICAL - $FREESPACE"
exit 2
fi
Тестирование:
$ check_disk_by_size.sh -H 192.168.6.31 -l c -w 10240 -c 5120
c:\_Drive_Space OK - free 13.01 Gb (36%)
$ check_disk_by_size.sh -H 192.168.6.31 -l c -w 14240 -c 5120
c:\_Drive_Space WARNING - free 13.01 Gb (36%)
$ check_disk_by_size.sh -H 192.168.6.31 -l c -w 16240 -c 15120
c:\_Drive_Space CRITICAL - free 13.01 Gb (36%)
Вы можете добавить его в Nagios так:
"check_disk_by_size.sh".
# 'check_disk_by_size' command definition
define command{
command_name check_disk_by_size
command_line $USER1$/check_disk_by_size.sh -H $HOSTADDRESS$ $ARG1$ $ARG2$ $ARG3$
}
define service{
use generic-service
host_name fileserver1
service_description Drive Space fileserver1: L:
check_command check_disk_by_size!-l L -w 4096 -c 2048
notifications_enabled 1
}
Я изменил код, чтобы адаптировать новый синтаксис BASH и более надежную проверку.
#!/bin/bash usage() { echo "$0 check_nt -H host [-p port] [-w warning] [-c critical] [-l params] [-t timeout]" 1>&2; exit 1; } while getopts ":H:p:l:w:c:" opt; do case "${opt}" in H ) HOST_NAME=$OPTARG;; p ) PORT=$OPTARG;; l ) DISC=$OPTARG;; w ) WARN_THRESHOLD=$OPTARG;; c ) CRITICAL_THRESHOLD=$OPTARG;; # t ) TIME_OUT=$OPTARG;; \?) echo "Invalid option: -$OPTARG" >&2; exit 1 ;; : ) echo "Option -$OPTARG requires an argument." >&2; exit 1;; esac done shift $((OPTIND-1)) if [[ -z "$HOST_NAME" ]] || [[ -z "$PORT" ]] || [[ -z "$DISC" ]] || [[ -z "$WARN_THRESHOLD" ]] || [[ -z "$CRITICAL_THRESHOLD" ]] ; then usage fi FREESPACE=`/usr/local/nagios/libexec/check_nt -H $HOST_NAME -p $PORT \ -v USEDDISKSPACE -l $DISC | awk -F"- " '{ print $4 }' | awk -F "|" '{ print $1 }'` SIZE=`echo $FREESPACE | awk '{ print $2 }'` UNIT=`echo $FREESPACE | awk '{ print $3 }'` if [[ $UNIT == "Gb" ]];then SIZE=`echo $SIZE \* 1024 | bc` fi if [[ `echo "$SIZE >= $WARN_THRESHOLD" | bc` -eq 1 ]];then echo "$DISC:\_Drive_Space OK - $FREESPACE" exit 0 elif [[ `echo "$SIZE $CRITICAL_THRESHOLD" | bc` -eq 1 ]];then echo "$DISC:\_Drive_Space WARNING - $FREESPACE" exit 1 elif [[ `echo "$SIZE
Я модифицировал сценарий Gnought, который является еще большей модификацией сценария Quanta, чтобы удалить некоторые ошибки кода и изменил результаты, чтобы они больше напоминали исходный результат check_nt, который дает лучшие данные при анализе тенденций с течением времени, а также данные о производительности, добавляемые обратно в.
#!/bin/bash
# Date: 2015-06-30
# Purpose: A wrapper script for check_nt to set threshold for exact space
# free rather than just percentage. Useful on VERY large drives.
# Example: check_disk_by_size.sh -H 192.168.0.1 -l c -w 10240 -c 5120
usage() { echo "$0 -H host [-s password] [-p port] [-w warning] [-c critical] [-l params]" 1>&2; exit 1; }
while getopts ":H:s:p:l:w:c:" opt; do
case "${opt}" in
H ) HOST_NAME=$OPTARG;;
s ) PASSW0RD=$OPTARG;;
p ) PORT=$OPTARG;;
l ) DISC=$OPTARG;;
w ) WARN_THRESHOLD=$OPTARG;;
c ) CRITICAL_THRESHOLD=$OPTARG;;
\?) echo "Invalid option: -$OPTARG" >&2; exit 1 ;;
: ) echo "Option -$OPTARG requires an argument." >&2; exit 1;;
esac
done
shift $((OPTIND-1))
if [[ -z "${HOST_NAME}" ]] || [[ -z "${PASSW0RD}" ]] || [[ -z "${PORT}" ]] || [[ -z "${DISC}" ]] || [[ -z "${WARN_THRESHOLD}" ]] || [[ -z "${CRITICAL_THRESHOLD}" ]] ; then
usage
fi
CHECKRESULT=`/usr/local/nagios/libexec/check_nt -H ${HOST_NAME} -p ${PORT} -s ${PASSW0RD} -v USEDDISKSPACE -l ${DISC}`
PERFDATA=`echo ${CHECKRESULT} | awk -F"- " '{ print $4 }' | awk -F "|" '{ print $2 }'`
FREESPACE=`echo ${CHECKRESULT} | awk -F"- " '{ print $4 }' | awk -F "|" '{ print $1 }'`
USEDSPACE=`echo ${CHECKRESULT} | awk -F"- " '{ print $3 }'`
TOTALSPACE=`echo ${CHECKRESULT} | awk -F"- " '{ print $2 }'`
if [[ -z ${FREESPACE} ]]; then
## Command failed or server offline
echo "ERROR ERROR: Command failed"
exit 1
fi
SIZE=`echo $FREESPACE | awk '{ print $2 }'`
UNIT=`echo $FREESPACE | awk '{ print $3 }'`
if [[ ${UNIT} == "Gb" ]]; then
SIZE=`echo ${SIZE} \* 1024 | bc`
fi
if [[ `echo "${SIZE} >= ${WARN_THRESHOLD}" | bc` -eq 1 ]]; then
echo "${DISC}:\ OK - ${TOTALSPACE} - ${USEDSPACE} - ${FREESPACE} | ${PERFDATA}"
exit 0
elif [[ `echo "${SIZE} < ${WARN_THRESHOLD}" | bc` -eq 1 && `echo "${SIZE} > ${CRITICAL_THRESHOLD}" | bc` -eq 1 ]]; then
echo "${DISC}:\ WARNING - ${TOTALSPACE} - ${USEDSPACE} - ${FREESPACE} | ${PERFDATA}"
exit 1
elif [[ `echo "${SIZE} <= ${CRITICAL_THRESHOLD}" | bc` -eq 1 ]]; then
echo "${DISC}:\ CRITICAL - ${TOTALSPACE} - ${USEDSPACE} - ${FREESPACE} | ${PERFDATA}"
exit 2
fi