diff options
-rw-r--r-- | net-mgmt/Makefile | 1 | ||||
-rw-r--r-- | net-mgmt/nagios-check_cpu_usage/Makefile | 26 | ||||
-rw-r--r-- | net-mgmt/nagios-check_cpu_usage/pkg-descr | 4 | ||||
-rw-r--r-- | net-mgmt/nagios-check_cpu_usage/src/check_cpu_usage | 120 |
4 files changed, 151 insertions, 0 deletions
diff --git a/net-mgmt/Makefile b/net-mgmt/Makefile index 7029b353bddc..1a0407acd6a6 100644 --- a/net-mgmt/Makefile +++ b/net-mgmt/Makefile @@ -115,6 +115,7 @@ SUBDIR += nagios-certexp-plugin SUBDIR += nagios-check_bacula SUBDIR += nagios-check_clamav + SUBDIR += nagios-check_cpu_usage SUBDIR += nagios-check_ice SUBDIR += nagios-check_kumofs SUBDIR += nagios-check_memcached_paranoid diff --git a/net-mgmt/nagios-check_cpu_usage/Makefile b/net-mgmt/nagios-check_cpu_usage/Makefile new file mode 100644 index 000000000000..2a0f2cfd4db9 --- /dev/null +++ b/net-mgmt/nagios-check_cpu_usage/Makefile @@ -0,0 +1,26 @@ +# New ports collection makefile for: nagios-check_cpu_usage +# Date created: 2010-11-23 +# Whom: jamrich.majo@gmail.com +# +# $FreeBSD$ +# + +PORTNAME= nagios-check_cpu_usage +PORTVERSION= 1.0 +CATEGORIES= net-mgmt +MASTER_SITES= # none +DISTFILES= # none + +MAINTAINER= jamrich.majo@gmail.com +COMMENT= Nagios plug-in to check CPU usage + +NO_BUILD= yes + +PLIST_DIRSTRY= libexec/nagios +PLIST_FILES= libexec/nagios/check_cpu_usage + +do-install: + @${MKDIR} ${PREFIX}/libexec/nagios + @${INSTALL_SCRIPT} ${.CURDIR}/src/check_cpu_usage ${PREFIX}/libexec/nagios + +.include <bsd.port.mk> diff --git a/net-mgmt/nagios-check_cpu_usage/pkg-descr b/net-mgmt/nagios-check_cpu_usage/pkg-descr new file mode 100644 index 000000000000..427dec2a1c7d --- /dev/null +++ b/net-mgmt/nagios-check_cpu_usage/pkg-descr @@ -0,0 +1,4 @@ +check_cpu_usage is a plugin intended for use with the Nagios network +monitoring system. This plugin checks the current CPU load and +compares the current state to given thresholds, returning the result. +It is written as shell script. diff --git a/net-mgmt/nagios-check_cpu_usage/src/check_cpu_usage b/net-mgmt/nagios-check_cpu_usage/src/check_cpu_usage new file mode 100644 index 000000000000..d9a9e4c8641d --- /dev/null +++ b/net-mgmt/nagios-check_cpu_usage/src/check_cpu_usage @@ -0,0 +1,120 @@ +#!/bin/sh +# +# Plugin return codes +# +# OK = 0 +# The plugin was able to check the service and it appeared to be +# functioning properly +# +# Warning = 1 +# The plugin was able to check the service, but it appeared to be above +# some "warning" threshold or did not appear to be working properly +# +# Critical = 2 +# The plugin detected that either the service was not running or it was +# above some "critical" threshold +# +# Unknown = 3 +# Invalid command line arguments were supplied to the plugin or low-level +# failures internal to the plugin (such as unable to fork, or open a tcp +# socket) that prevent it from performing the specified operation. +# Higher-level errors (such as name resolution errors, socket timeouts, etc) +# are outside of the control of plugins and should generally NOT be reported +# as UNKNOWN states. + +# default path +PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/local/sbin:/usr/local/bin + +ST_OK=0 +ST_WR=1 +ST_CR=2 +ST_UN=3 + +# Plugin name +PROGNAME=`basename $0` + +# Version +VERSION="Version 1.0" + +# Author +AUTHOR="Majo Jamrich" + + +print_version() { + echo "$PROGNAME $VERSION $1" +} + +print_help() { + print_version "($AUTHOR)" + echo "" + echo "$PROGNAME is a Nagios plugin to check CPU utilization." + echo "" + echo "Options:" + echo "" + echo "--warning | -w" + echo "--critical | -c" + echo "--help | --usage" + echo "" + echo "Usage:" + echo "./check_cpu_usage -w 80 -c 100" + echo "" + exit $ST_UN +} + +case "$1" in + --help|-h|--usage|-u) + print_help + exit $ST_UN + ;; + --warning|-w) + host=$2 + ;; + --critical|-c) + host=$2 + ;; + -V) + print_version + exit + ;; + *) + echo "Unknown argument: $1" + echo "For more information please try -h or --help!" + exit $ST_UN + ;; +esac +shift + +if [ `uname` != "FreeBSD" ]; then + echo "This plugin is only for FreeBSD." +fi + +if [ -z $1 ] || [ -z $3 ]; then + print_help + exit $ST_UN +fi + +if [ "$1" -ge "$3" ]; then + echo "Warning value must be greater than critical value!" + exit $ST_UN +fi + +warn=$1 +crit=$3 + +cpu_all=$( vmstat -c 2 -n 0 | tail -n 1 | awk '{print $15 " " $16 " " $17}' ) +cpu_user=$( echo $cpu_all | awk '{print $1}') +cpu_sys=$( echo $cpu_all | awk '{print $2}') +cpu_idle=$( echo $cpu_all | awk '{print $3}') +cpu_usage=$(( 100 - $cpu_idle )) +perfdata="cpu_usage=$cpu_usage%;$warn;$crit; cpu_user=$cpu_user%; cpu_system=$cpu_sys%;" + +if [ $( echo "$cpu_usage>$1" | bc ) -gt 0 ] && [ $( echo "$cpu_usage<$3" | bc ) -gt 0 ]; then + echo "WARNING - CPU usage is $cpu_usage% for server `hostname`. |$perfdata" + exit $ST_WR +elif [ $( echo "$cpu_usage>$3" | bc ) -gt 0 ]; then + echo "CRITICAL - CPU usage is $cpu_usage% for server `hostname`. |$perfdata" + exit $ST_CR +else + echo "OK - CPU usage is $cpu_usage% for server `hostname`. |$perfdata" + exit $ST_OK +fi |