1
0
mirror of https://github.com/opinkerfi/nagios-plugins.git synced 2024-11-23 02:43:45 +01:00
nagios-plugins/check_eva/trunk/check_eva

183 lines
3.8 KiB
Plaintext
Raw Normal View History

2010-08-17 12:50:27 +02:00
#!/bin/sh
# Some defaults
hostaddress=evahost
username=eva
password=eva1234
2010-08-17 12:50:27 +02:00
BODYFILE=/tmp/check_eva.body
LASTCHECK=`ls -la /etc/sssu.out | awk ' { print $6,$7,$8 }'`
COMMANDFILE="/etc/nagios/check_eva.sssu"
VERSION=1.0
OK=0
WARNING=1
CRITICAL=2
UNKNOWN=3
print_help() {
echo "check_eva version $VERSION"
echo "This plugin checks status of HP EVA Array via sssu command"
echo ""
echo "Usage: $0 [OPTIONS]"
echo "Options:"
echo "[-H <host>]"
echo "[--username <user>]"
echo "[--password <password]"
echo "[--test]"
echo "[--help]"
echo ""
}
# Parse arguments
while [ $# -gt 0 ]
do
case $1
in
-H)
hostaddress=$2
shift 2
;;
--username)
username=$2
shift 2
;;
--password)
password=$2
shift 2
;;
-P)
password=$2
shift 2
;;
-U)
username=$2
shift 2
;;
--test)
testmode=$1
shift 1
;;
--help)
print_help ;
exit $OK
;;
*)
print_help ;
exit $UNKNOWN
;;
esac
done
2010-08-17 12:50:27 +02:00
# Compatibility with old style use case of this file
if [ $# -eq 0 ]; then
if [ ! -f $COMMANDFILE ]; then
echo "Error, could not find commandfile $COMMANDFILE"
exit 3
fi
/usr/local/sbin/sssu "file $COMMANDFILE" |grep -v PASSWORD > /etc/sssu.out
2010-08-17 12:50:27 +02:00
fi
# Only run actual SSSU command if this is not a test run
#if [ -z $testmode ]; then
# /usr/local/sbin/sssu "file $COMMANDFILE" |grep -v PASSWORD > /etc/sssu.out
#fi
# Run the actual sssu command
CMD1="set option on_error=continue"
CMD2="select manager $hostaddress USERNAME=$username PASSWORD=$password"
CMD3="ls system full"
if [ "$DEBUG" == "1" ]; then
echo "Debug: $CMD2"
fi
/usr/local/sbin/sssu "$CMD1" "$CMD2" "$CMD3" | grep -v PASSWORD > /etc/sssu.out
2010-08-17 12:50:27 +02:00
PROBLEM=`grep -w operationalstate /etc/sssu.out |grep -v good |wc -l`
2010-08-30 14:50:01 +02:00
ERRORCHECK1=`grep -i error /etc/sssu.out| grep -v on_error | wc -l`
ERRORCHECK2=`grep -w operationalstate /etc/sssu.out | wc -l`
2010-08-17 12:50:27 +02:00
SUMMARY=`awk ' $1 == "objectname" { STORAGE=$3 } \
$1 == "operationalstate" { STATE=$3 } \
2010-08-30 14:50:01 +02:00
$1 == "managementhostname" { print STORAGE "=" STATE ";" } ' /etc/sssu.out | tr '\n' ' '`
PERFDATA=`awk ' $1 == "objectname" { STORAGE=$3 } \
$1 == "totalstoragespace" { totalstoragespace=STORAGE "_" $1 "=" $3 } \
$1 == "usedstoragespace" { usedstoragespace=STORAGE "_" $1 "=" $3 } \
$1 == "availablestoragespace" { availablestoragespace=STORAGE "_" $1 "=" $3 } \
$1 == "managementhostname" { print totalstoragespace, usedstoragespace, availablestoragespace } ' /etc/sssu.out | tr '\n' ' '`
2010-08-17 12:50:27 +02:00
2010-08-30 14:50:01 +02:00
#totalstoragespace=`grep totalstoragespace /etc/sssu.out | awk '{ print $3 }' | tr '\n' ' ' `
#usedstoragespace=`grep usedstoragespace /etc/sssu.out | awk '{ print $3 }' | tr '\n' ' '`
#availablestoragespace=`grep availablestoragespace /etc/sssu.out | awk '{ print $3 }' | tr '\n' ' '`
#PERFDATA="totalstoragespace=$totalstoragespace usedstoragespace=$usedstoragespace availablestoragespace=$availablestoragespace"
2010-08-17 12:50:27 +02:00
if [ "$PROBLEM" -gt 0 ]; then
2010-08-30 14:50:01 +02:00
echo "Warning - HP EVA Requires attention. $SUMMARY | $PERFDATA"
echo "EVA state last checked at $LASTCHECK"
grep -E 'operationalstate|operationalstatedetail|objectname|licensestate|systemtype|storagespace' /etc/sssu.out
exit 1
2010-08-17 12:50:27 +02:00
fi
2010-08-30 14:50:01 +02:00
if [ "$ERRORCHECK1" -gt 0 ]; then
echo "Unknown - failed to run sssu command"
cat /etc/sssu.out
exit 3
fi
if [ "$ERRORCHECK2" -lt 1 ]; then
echo "Unknown - Could not retrieve information via sssu"
cat /etc/sssu.out
exit 3
fi
echo "OK - HP EVA reports: $SUMMARY | $PERFDATA"
2010-08-17 12:50:27 +02:00
echo "EVA state last checked at $LASTCHECK"
2010-08-30 14:50:01 +02:00
grep -E 'operationalstate|operationalstatedetail|objectname|licensestate|systemtype|storagespace' /etc/sssu.out
2010-08-17 12:50:27 +02:00