diff options
| author | Mike Gabriel <mike.gabriel@das-netzwerkteam.de> | 2016-07-15 22:29:49 +0200 | 
|---|---|---|
| committer | Mike Gabriel <mike.gabriel@das-netzwerkteam.de> | 2016-07-15 22:30:34 +0200 | 
| commit | 11f953db29578dca08dc62132130d09c30a3e9ca (patch) | |
| tree | 1d16992129a4173a31449d00ea339ef9d9590a08 | |
| parent | 3a77d269be0e57f2fd3f63db2ac6d6700286c447 (diff) | |
| download | itzks-systems-11f953db29578dca08dc62132130d09c30a3e9ca.tar.gz itzks-systems-11f953db29578dca08dc62132130d09c30a3e9ca.tar.bz2 itzks-systems-11f953db29578dca08dc62132130d09c30a3e9ca.zip | |
Icinga2 monitoring plugins: Add check_md_raid (physical servers) and check_squid (main server).
| -rw-r--r-- | debian/control | 2 | ||||
| -rw-r--r-- | debian/itzks-systems-backup.install | 1 | ||||
| -rw-r--r-- | debian/itzks-systems-mainserver.install | 1 | ||||
| -rw-r--r-- | debian/itzks-systems-virtman.install | 1 | ||||
| -rw-r--r-- | usr-lib-nagios-plugins/check_md_raid | 36 | ||||
| -rw-r--r-- | usr-lib-nagios-plugins/check_squid | 269 | 
6 files changed, 310 insertions, 0 deletions
| diff --git a/debian/control b/debian/control index 759eda4..d2145fe 100644 --- a/debian/control +++ b/debian/control @@ -203,6 +203,7 @@ Depends:   gdisk,   htop,   itzks-keyring, + libnagios-plugin-perl,   links,   linuxlogo,   mate-desktop-environment-core, @@ -216,6 +217,7 @@ Depends:   pkg-mozilla-archive-keyring,   pxelinux,   reportbug, + squidclient,   syslinux,   sysstat,   tree, diff --git a/debian/itzks-systems-backup.install b/debian/itzks-systems-backup.install new file mode 100644 index 0000000..9301dd2 --- /dev/null +++ b/debian/itzks-systems-backup.install @@ -0,0 +1 @@ +usr-lib-nagios-plugins/check_md_raid usr/lib/nagios/plugins/ diff --git a/debian/itzks-systems-mainserver.install b/debian/itzks-systems-mainserver.install index 0df69cf..f6d2853 100644 --- a/debian/itzks-systems-mainserver.install +++ b/debian/itzks-systems-mainserver.install @@ -1,3 +1,4 @@  sbin/itzks-transfer-cleaner usr/sbin  etc/skel etc/  etc/cron.d/itzks-transfer-cleaner /etc/cron.d/ +usr-lib-nagios-plugins/check_squid usr/lib/nagios/plugins/ diff --git a/debian/itzks-systems-virtman.install b/debian/itzks-systems-virtman.install new file mode 100644 index 0000000..9301dd2 --- /dev/null +++ b/debian/itzks-systems-virtman.install @@ -0,0 +1 @@ +usr-lib-nagios-plugins/check_md_raid usr/lib/nagios/plugins/ diff --git a/usr-lib-nagios-plugins/check_md_raid b/usr-lib-nagios-plugins/check_md_raid new file mode 100644 index 0000000..07d9682 --- /dev/null +++ b/usr-lib-nagios-plugins/check_md_raid @@ -0,0 +1,36 @@ +#!/bin/bash +# +# Created by Sebastian Grewe, Jammicron Technology +# + +# Get count of raid arrays +RAID_DEVICES=`grep ^md -c /proc/mdstat` + +# Get count of degraded arrays +RAID_STATUS=`grep "\[.*_.*\]" /proc/mdstat -c` + +# Is an array currently recovering, get percentage of recovery +RAID_RECOVER=`grep recovery /proc/mdstat | awk '{print $4}'` +RAID_RESYNC=`grep resync /proc/mdstat | awk '{print $4}'` + +# Check raid status +# RAID recovers --> Warning +if [[ $RAID_RECOVER ]]; then +	STATUS="WARNING - Checked $RAID_DEVICES arrays, recovering : $RAID_RECOVER" +	EXIT=1 +elif [[ $RAID_RESYNC ]]; then +	STATUS="WARNING - Checked $RAID_DEVICES arrays, resync : $RAID_RESYNC" +	EXIT=1 +# RAID ok +elif [[ $RAID_STATUS == "0" ]]; then +	STATUS="OK - Checked $RAID_DEVICES arrays." +	EXIT=0 +# All else critical, better save than sorry +else +	STATUS="CRITICAL - Checked $RAID_DEVICES arrays, $RAID_STATUS have FAILED" +	EXIT=2 +fi + +# Status and quit +echo $STATUS +exit $EXIT diff --git a/usr-lib-nagios-plugins/check_squid b/usr-lib-nagios-plugins/check_squid new file mode 100644 index 0000000..804d664 --- /dev/null +++ b/usr-lib-nagios-plugins/check_squid @@ -0,0 +1,269 @@ +#!/usr/bin/perl +################################################################### +# check_squid is developped with GPL Licence 2.0 +# +# GPL License: http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt +# +# Developped by : Cyril Feraudet +# +################################################################### +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License +# as published by the Free Software Foundation; either version 2 +# of the License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +# GNU General Public License for more details. +# +#    For information : cyril@feraudet.com +#################################################################### + +my $VERSION = "1.1"; + +$|; +use Nagios::Plugin; +# todo : use strict; + + +$np = Nagios::Plugin->new(usage => "Usage: %s [ -v|--verbose ] [ -H <host> ] [ -d <data> ] [ -p <port> ] [ -t <timeout>] [ -c <threshold> ] [ -w <threshold> ]", version => $VERSION); + +$np->add_arg( +    spec => 'host|H=s', +    help => "-H, --host=<hostname>\n" +    . "	Name of the proxy to check (default: localhost)", +    required => 0 +); + +$np->add_arg( # Connections Cache Resources Memory FileDescriptors +    spec => 'data|d=s', +    help => "-d, --data=<data>\n" +    . "	Optional data to fetch (default: Connections)" +    . "	available data : Connections Cache Resources Memory FileDescriptors", +    required => 0 +); + +$np->add_arg( +    spec => 'port|p=i', +    help => "-p, --port=<port>\n" +    . "	Optional port number (default: 3128)", +    required => 0 +); + +$np->add_arg( +    spec => 'user|U=s', +    help => "-U, --user=<user>\n" +    . "	Optional WWW user (default: root)", +    required => 0 +); + +$np->add_arg( +    spec => 'password|W=s', +    help => "-W, --password=<password>\n" +    . "	Optional WWW password", +    required => 0 +); + +$np->add_arg( +    spec => 'warning|w=s', +    help => "-w, --warning=THRESHOLD\n" +    . "	Warning threshold. See\n" +    . "	http://nagiosplug.sourceforge.net/developer-guidelines.html#THRESHOLDFORMAT\n" +    . '	for the threshold format.', +    required => 0, +); + +$np->add_arg( +    spec => 'critical|c=s', +    help => "-c, --critical=THRESHOLD\n" +    . "	Critical threshold. See\n" +    . "	http://nagiosplug.sourceforge.net/developer-guidelines.html#THRESHOLDFORMAT\n" +    . '	for the threshold format.', +    required => 0, +); + +$np->add_arg( +    spec => 'squidclient|s=s', +    help => "-s, --squidclient=<squidclient_path>\n" +    . "	Path of squidclient (default: /usr/bin/squidclient)", +    required => 0, +); + +$np->getopts; + +my $host = $np->opts->host; +my $port = $np->opts->port; +my $data = $np->opts->data; +my $user = $np->opts->user; +my $password = $np->opts->password; +my $critical = $np->opts->critical; +my $warning = $np->opts->warning; +my $squidclient = $np->opts->squidclient; + + +my $output = ""; +$host = 'localhost' if (!defined($host) or $host eq ''); +$port = 3128 if (!defined($port) or $port eq ''); +$data = 'Connections' if (!defined($data) or $data eq ''); +$user = 'root' if (!defined($user) or $user eq ''); +$password = '' if (!defined($password)); +$critical = undef if (defined($critical) and $critical eq ''); +$warning = undef if (defined($warning) and $warning eq ''); +$squidclient = '/usr/bin/squidclient' if (!defined($squidclient) or $squidclient eq ''); + +if (! ( -f "$squidclient" && -x _ )) { +    $output = "$squidclient not found or not executable\n"; +    $np->nagios_exit('UNKNOWN', $output); +} + +$np->set_thresholds(critical => $critical, warning => $warning); + +# squidclient -h localhost -p 8080 -U root -W FPSlsker mgr:info + +@exec = ("-h", "\Q$host", "-p", "\Q$port", "-U", "\Q$user", "-W", "\Q$password", "mgr:info"); + +@result = `$squidclient @exec`; + +my $fd_available; +my $fd_used; +my $memory_available; +my $memory_used; +my $connection_nbclient; +my $connection_nbicpreceived; +my $connection_nbicpsent; +my $connection_nbicpqueued; +my $cache_requesthitratio5; +my $cache_requesthitratio60; +my $cache_bytehitratio5; +my $cache_bytehitratio60; +for my $line (@result) +{ +    chomp($line); +# Connection information for squid: +#      Number of clients accessing cache:      1203 +    $line =~ /\s+Number of clients accessing cache:\s+([0-9]+)/ and $connection_nbclient = $1; +#      Number of HTTP requests received:       8892278 +    $line =~ /\s+Number of HTTP requests received:\s+([0-9]+)/ and $connection_nbhttpreceived = $1; +#      Number of ICP messages received:        0 +    $line =~ /\s+Number of ICP messages received:\s+([0-9]+)/ and $connection_nbicpreceived = $1; +#      Number of ICP messages sent:    0 +    $line =~ /\s+Number of ICP messages sent:\s+([0-9]+)/ and $connection_nbicpsent = $1; +#      Number of queued ICP replies:   0 +    $line =~ /\s+Number of queued ICP replies:\s+([0-9]+)/ and $connection_nbicpqueued = $1; +#      Request failure ratio:   0.00 +#      Average HTTP requests per minute since start:   1247.5 +#      Average ICP messages per minute since start:    0.0 +#      Select loop called: 407414146 times, 1.050 ms avg +# Cache information for squid: +#      Request Hit Ratios:     5min: 32.8%, 60min: 33.9% +    $line =~ /\s+Request Hit Ratios:\s+5min:\s+([0-9\.]+)%,\s+60min:\s+([0-9\.]+)%/ and $cache_requesthitratio5 = $1 and $cache_requesthitratio60 = $2; +#      Byte Hit Ratios:        5min: 23.7%, 60min: 20.9% +    $line =~ /\s+Byte Hit Ratios:\s+5min:\s+([0-9\.]+)%,\s+60min:\s+([0-9\.]+)%/ and $cache_bytehitratio5 = $1 and $cache_bytehitratio60 = $2; +    $line =~ /\s+Hits as % of all requests:\s+5min:\s+([0-9\.]+)%,\s+60min:\s+([0-9\.]+)%/ and $cache_requesthitratio5 = $1 and $cache_requesthitratio60 = $2; +#      Byte Hit Ratios:        5min: 23.7%, 60min: 20.9% +    $line =~ /\s+Hits as % of bytes sent:\s+5min:\s+([0-9\.]+)%,\s+60min:\s+([0-9\.]+)%/ and $cache_bytehitratio5 = $1 and $cache_bytehitratio60 = $2; +#      Request Memory Hit Ratios:      5min: 20.3%, 60min: 24.9% +#      Request Disk Hit Ratios:        5min: 25.0%, 60min: 23.9% +#      Storage Swap size:      27694948 KB +#      Storage Mem size:       614304 KB +#      Mean Object Size:       26.96 KB +#      Requests given to unlinkd:      1318030 +# Median Service Times (seconds)  5 min    60 min: +#      HTTP Requests (All):   0.03622  0.02742 +#      Cache Misses:          0.07825  0.06640 +#      Cache Hits:            0.00091  0.00091 +#      Near Hits:             0.03241  0.04047 +#      Not-Modified Replies:  0.00091  0.00000 +#      DNS Lookups:           0.00094  0.00094 +#      ICP Queries:           0.00000  0.00000 +# Resource usage for squid: +#      UP Time:        427690.730 seconds +#      CPU Time:       7524.043 seconds +#      CPU Usage:      1.76% +    $line =~ /\s+CPU Usage:\s+([0-9\.]+)%/ and $resource_cpu5s = $1; +#      CPU Usage, 5 minute avg:        7.99% +    $line =~ /\s+CPU Usage, 5 minute avg:\s+([0-9\.]+)%/ and $resource_cpu5m = $1; +#      CPU Usage, 60 minute avg:       10.03% +    $line =~ /\s+CPU Usage, 60 minute avg:\s+([0-9\.]+)%/ and $resource_cpu60m = $1; +#      Process Data Segment Size via sbrk(): 875680 KB +#      Maximum Resident Size: 0 KB +#      Page faults with physical i/o: 2 +# Memory usage for squid via mallinfo(): +#      Total space in arena:  875812 KB +#      Ordinary blocks:       811063 KB  97332 blks +#      Small blocks:               0 KB      0 blks +#      Holding blocks:          3996 KB      6 blks +#      Free Small blocks:          0 KB +#      Free Ordinary blocks:   64748 KB +#      Total in use:          815059 KB 93% +    $line =~ /\s+Total in use:\s+([0-9]+)/ and $memory_used = $1; +#      Total free:             64748 KB 7% +#      Total size:            879808 KB +    $line =~ /\s+Total size:\s+([0-9]+)/ and $memory_available = $1; +# Memory accounted for: +#      Total accounted:       750343 KB +#      memPoolAlloc calls: 1149188126 +#      memPoolFree calls: 1144643200 +# File descriptor usage for squid: +#      Maximum number of file descriptors:   4096 +#      Largest file desc currently in use:    718 +#      Number of file desc currently in use:  692 +#      Files queued for open:                   0 +#      Available number of file descriptors: 3404 +#      Reserved number of file descriptors:   100 +#      Store Disk files open:                   2 +#      IO loop method:                     epoll +    $line =~ /\s+Maximum number of file descriptors:\s+([0-9]+)/ and $fd_available = $1; +    $line =~ /\s+Number of file desc currently in use:\s+([0-9]+)/ and $fd_used = $1; +# Internal Data Structures: +#      1027146 StoreEntries +#       50047 StoreEntries with MemObjects +#       50004 Hot Object Cache Items +#      1027079 on-disk objects +} + +if($data =~ /Connections/i)  # Connections Cache Resources Memory FileDescriptors +{ +    $np->add_perfdata( label => "HTTP requests", value => $connection_nbhttpreceived, uom => "c"); +    $np->add_perfdata( label => "sent ICP requests", value => $connection_nbicpsent, uom => "c"); +    $np->add_perfdata( label => "received ICP requests", value => $connection_nbicpreceived, uom => "c"); +    $np->nagios_exit('OK', "Squid have $connection_nbclient clients and $connection_nbicpqueued ICP requests queued"); +} +if($data =~ /Cache/i) +{ +    $np->add_perfdata( label => "Requests Hit Ratio 5min", value => $cache_requesthitratio5, uom => "%"); +    $np->add_perfdata( label => "Requests Hit Ratio 60min", value => $cache_requesthitratio60, uom => "%"); +    $np->add_perfdata( label => "Byte Hit Ratio 5min", value => $cache_bytehitratio5, uom => "%"); +    $np->add_perfdata( label => "Byte Hit Ratio 60min", value => $cache_bytehitratio60, uom => "%"); +    $np->nagios_exit('OK', "Requests Hit Ratio 5min: $cache_requesthitratio5, Requests Hit Ratio 60min: $cache_requesthitratio60, Byte Hit Ratio 5min: $cache_bytehitratio5, Byte Hit Ratio 60min: $cache_bytehitratio60"); +} +if($data =~ /Resources/i) +{ +    $np->add_perfdata( label => "CPU used 5s", value => $resource_cpu5s, uom => "%"); +    $np->add_perfdata( label => "CPU used 5m", value => $resource_cpu5m, uom => "%"); +    $np->add_perfdata( label => "CPU used 60m", value => $resource_cpu60m, uom => "%"); +    $np->nagios_exit('OK', "CPU used 5s: $resource_cpu5s, CPU used 5m: $resource_cpu5m, CPU used 60m: $resource_cpu60m"); +} +if($data =~ /Memory/i) +{ +    my $t = Nagios::Plugin::Threshold->set_thresholds(warning  => $warning, critical => $critical); +    $np->add_perfdata( label => "Memory used", value => $memory_used, uom => "KB", threshold => $t); +    $np->add_perfdata( label => "Memory available", value => $memory_available, uom => "KB"); +    $np->nagios_exit($np->check_threshold($memory_used), "Squid use $memory_used KB of memory"); +} +if($data =~ /FileDescriptors/i) +{ +    my $t = Nagios::Plugin::Threshold->set_thresholds(warning  => $warning, critical => $critical); +    $np->add_perfdata( label => "Max FD", value => $fd_available); +    $np->add_perfdata( label => "Cur FD", value => $fd_used, threshold => $t); +    $np->nagios_exit($np->check_threshold($fd_used), 'Squid work fine.'); +} + + + +# $np->nagios_exit('OK', $output); +# $np->nagios_exit('WARNING', $output); +# $np->nagios_exit('CRITICAL', $output); +# $np->nagios_exit('UNKNOWN', $output); +# $np->nagios_exit('DEPENDENT', $output); | 
