mirror of
https://github.com/opinkerfi/nagios-plugins.git
synced 2026-02-13 02:20:57 +01:00
Compare commits
140 Commits
nagios-okp
...
plugin-che
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d9b0b77dc1 | ||
|
|
23714fa9cd | ||
|
|
22062ef76f | ||
|
|
ee29f68bcc | ||
|
|
077e862e6f | ||
|
|
b96bb5e207 | ||
|
|
f774b44b47 | ||
|
|
51c659990b | ||
|
|
343c42339f | ||
|
|
8f89f773e3 | ||
|
|
24518a74e7 | ||
|
|
cdc1daad6d | ||
|
|
c40bee725a | ||
|
|
892f9c267e | ||
|
|
3501677f20 | ||
|
|
6726f614ad | ||
|
|
ee5adc2363 | ||
|
|
7dc3b57582 | ||
|
|
688e8b8412 | ||
|
|
1ccc433779 | ||
|
|
ee05a4f24a | ||
|
|
871c8348fa | ||
|
|
944d47e18e | ||
|
|
40ba14c4cb | ||
|
|
f986b73474 | ||
|
|
c8e7fbbff8 | ||
|
|
f23ac92b64 | ||
|
|
7ab36cbc66 | ||
|
|
bf0edd899b | ||
|
|
9060a171f0 | ||
|
|
1420e93c5c | ||
|
|
cbcaa14997 | ||
|
|
03f7389842 | ||
|
|
f186de5585 | ||
|
|
c22b89893d | ||
|
|
d3f75ec93a | ||
|
|
9862b3c0d9 | ||
|
|
790619d820 | ||
|
|
a743def0c8 | ||
|
|
c414e17b30 | ||
|
|
b481aadbd5 | ||
|
|
2049fbd692 | ||
|
|
5f604b852f | ||
|
|
e5772ab336 | ||
|
|
e5498e1554 | ||
|
|
7d9ba339bc | ||
|
|
37d504a039 | ||
|
|
e7af0e4098 | ||
|
|
6c126130cc | ||
|
|
f0968997e4 | ||
|
|
95693e3c73 | ||
|
|
55daf8f4c9 | ||
|
|
d11d29185a | ||
|
|
06194c84cc | ||
|
|
184d7d3b4a | ||
|
|
1574cd13d3 | ||
|
|
b0b55dcd3e | ||
|
|
b96e973e60 | ||
|
|
51b75943cf | ||
|
|
8ff1cf84d0 | ||
|
|
5cb19c072e | ||
|
|
6db73d28d6 | ||
|
|
5ba61f91b2 | ||
|
|
8f6faa8b59 | ||
|
|
574538883c | ||
|
|
245ad9ba21 | ||
|
|
854b08c601 | ||
|
|
55ea04bd73 | ||
|
|
09dcc39f94 | ||
|
|
48d0a92707 | ||
|
|
e9222eb215 | ||
|
|
e64d51ebc3 | ||
|
|
5d94c9d3a2 | ||
|
|
22e4293db7 | ||
|
|
9b89a3d998 | ||
|
|
553a182dd1 | ||
|
|
9501bef37b | ||
|
|
b672f6f508 | ||
|
|
04d25281e3 | ||
|
|
9b2474fb49 | ||
|
|
156459046c | ||
|
|
a93d887721 | ||
|
|
2dbec06282 | ||
|
|
734e7d5596 | ||
|
|
623c1d5159 | ||
|
|
19312f9b55 | ||
|
|
c1005cb911 | ||
|
|
f5d4cde8b5 | ||
|
|
067f58f52e | ||
|
|
5d0df0bfe9 | ||
|
|
735b2795d8 | ||
|
|
5593391a3b | ||
|
|
ee4b10b291 | ||
|
|
b10d555e52 | ||
|
|
971afc97f7 | ||
|
|
fcf90cae3e | ||
|
|
73b632a828 | ||
|
|
b375ae66ee | ||
|
|
3606e03170 | ||
|
|
63f285a037 | ||
|
|
be7032f4e4 | ||
|
|
d259894a9d | ||
|
|
6d0ce2c869 | ||
|
|
4aae5f6327 | ||
|
|
2112847349 | ||
|
|
f382acb1a6 | ||
|
|
d7efe24a34 | ||
|
|
72f2c0de16 | ||
|
|
7c41c09b2f | ||
|
|
f87963f554 | ||
|
|
38a207065e | ||
|
|
831156308b | ||
|
|
356bb2c762 | ||
|
|
bc15b653b1 | ||
|
|
814426a5a8 | ||
|
|
2f69dd02cb | ||
|
|
25b04e822e | ||
|
|
f3909a08f6 | ||
|
|
53ec813478 | ||
|
|
46024baa26 | ||
|
|
3d867d84c0 | ||
|
|
6562732a91 | ||
|
|
c524ee0046 | ||
|
|
9907356c39 | ||
|
|
39f2413957 | ||
|
|
840ef78a7b | ||
|
|
c6cb2b634d | ||
|
|
92a6643a4b | ||
|
|
a21b3adf43 | ||
|
|
39b7d6a7d9 | ||
|
|
598a525ac8 | ||
|
|
ceb039eb45 | ||
|
|
5ab6e198ec | ||
|
|
b0663e0495 | ||
|
|
a01af47d86 | ||
|
|
30c4b15700 | ||
|
|
1099ad9c02 | ||
|
|
677ec90e3e | ||
|
|
a5dbf632f2 | ||
|
|
5af347c3df |
@@ -1,4 +1,5 @@
|
|||||||
#!/usr/bin/perl
|
#!/usr/bin/perl
|
||||||
|
# nagios: -epn
|
||||||
#
|
#
|
||||||
# check_apcext.pl - APC Extra gear monitoring plugin for Nagios
|
# check_apcext.pl - APC Extra gear monitoring plugin for Nagios
|
||||||
# 05.02.07 Paul Venezia
|
# 05.02.07 Paul Venezia
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check APC devices
|
Summary: A Nagios plugin to check APC devices
|
||||||
Name: nagios-okplugin-apc
|
Name: nagios-okplugin-apc
|
||||||
Version: 2.1.0
|
Version: 2.1.2
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -38,6 +38,15 @@ rm -rf %{buildroot}
|
|||||||
%{_libdir}/nagios/plugins/*
|
%{_libdir}/nagios/plugins/*
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Mon Jun 09 2014 Tomas Edwardsson <tommi@tommi.org> 2.1.2-1
|
||||||
|
- Disable embedded perl (tommi@tommi.org)
|
||||||
|
|
||||||
|
* Thu Mar 20 2014 Tomas Edwardsson <tommi@tommi.org> 2.1.1-1
|
||||||
|
- Merge github.com:opinkerfi/misc (palli@opensource.is)
|
||||||
|
- Use the right value for the job nbmstemp (tommi@tommi.org)
|
||||||
|
- Fixed metric conversion for all mibs (tommi@opensource.is)
|
||||||
|
- Added fahrenheit to celsius conversion (tommi@tommi.org)
|
||||||
|
|
||||||
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 2.1.0-1
|
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 2.1.0-1
|
||||||
- Version number bumped to 2.1.0 (palli@opensource.is)
|
- Version number bumped to 2.1.0 (palli@opensource.is)
|
||||||
- Added noarch buildarch (tommi@tommi.org)
|
- Added noarch buildarch (tommi@tommi.org)
|
||||||
|
|||||||
@@ -2,8 +2,8 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check SMTP blacklists
|
Summary: A Nagios plugin to check SMTP blacklists
|
||||||
Name: nagios-okplugin-mailblacklist
|
Name: nagios-okplugin-mailblacklist
|
||||||
Version: 1.0
|
Version: 1.1
|
||||||
Release: 1%{?dist}
|
Release: 2%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
URL: http://opensource.ok.is/trac/wiki/Nagios-OKPlugin-MailBlacklist
|
URL: http://opensource.ok.is/trac/wiki/Nagios-OKPlugin-MailBlacklist
|
||||||
@@ -11,7 +11,7 @@ Source0: http://opensource.ok.is/trac/browser/nagios-plugins/check_bl/releases/%
|
|||||||
Requires: nagios-plugins
|
Requires: nagios-plugins
|
||||||
Requires: nagios-plugins-perl
|
Requires: nagios-plugins-perl
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
Packager: Tomas Edwardsson <tommi@ok.is>
|
Packager: Gardar Thorsteinsson <gardar@ok.is>
|
||||||
BuildArch: noarch
|
BuildArch: noarch
|
||||||
|
|
||||||
|
|
||||||
@@ -22,6 +22,8 @@ Checks DNS Blacklists for existance of hosts
|
|||||||
%setup -q
|
%setup -q
|
||||||
perl -pi -e "s|/usr/lib|%{_libdir}|g" check_bl
|
perl -pi -e "s|/usr/lib|%{_libdir}|g" check_bl
|
||||||
|
|
||||||
|
%global __requires_exclude %{?__requires_exclude:%__requires_exclude}|}^perl\\(utils\\)
|
||||||
|
|
||||||
%build
|
%build
|
||||||
|
|
||||||
|
|
||||||
@@ -38,6 +40,12 @@ rm -rf %{buildroot}
|
|||||||
%{_libdir}/nagios/plugins/*
|
%{_libdir}/nagios/plugins/*
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri May 04 2018 Richard Allen <ra@ok.is> 1.1-2
|
||||||
|
- Filter out perl-utils dependancy
|
||||||
|
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 1.1-1
|
||||||
|
-
|
||||||
|
|
||||||
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.0-1
|
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.0-1
|
||||||
- Updated buildarch to noarch (tommi@tommi.org)
|
- Updated buildarch to noarch (tommi@tommi.org)
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check network bond devices
|
Summary: A Nagios plugin to check network bond devices
|
||||||
Name: nagios-okplugin-bond
|
Name: nagios-okplugin-bond
|
||||||
Version: 0.0.3
|
Version: 0.0.4
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -40,6 +40,10 @@ rm -rf %{buildroot}
|
|||||||
%config(noreplace) %{_sysconfdir}/nrpe.d/check_bond.cfg
|
%config(noreplace) %{_sysconfdir}/nrpe.d/check_bond.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 0.0.4-1
|
||||||
|
- Merge pull request #5 from pallvalmundsson/check_yum_security_patch (palli-
|
||||||
|
github@minor.is)
|
||||||
|
|
||||||
* Wed Mar 13 2013 Pall Sigurdsson <palli@opensource.is> 0.0.3-1
|
* Wed Mar 13 2013 Pall Sigurdsson <palli@opensource.is> 0.0.3-1
|
||||||
-
|
-
|
||||||
|
|
||||||
|
|||||||
@@ -2,15 +2,15 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check Brocade devices
|
Summary: A Nagios plugin to check Brocade devices
|
||||||
Name: nagios-okplugin-brocade
|
Name: nagios-okplugin-brocade
|
||||||
Version: 0.0.4
|
Version: 0.0.5
|
||||||
Release: 1%{?dist}
|
Release: 2%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
URL: http://opensource.ok.is/trac/wiki/Nagios-OKPlugin-Brocade
|
URL: http://opensource.ok.is/trac/wiki/Nagios-OKPlugin-Brocade
|
||||||
Source0: http://opensource.ok.is/trac/browser/nagios-plugins/check_brocade/releases/nagios-okplugin-brocade-%{version}.tar.gz
|
Source0: http://opensource.ok.is/trac/browser/nagios-plugins/check_brocade/releases/nagios-okplugin-brocade-%{version}.tar.gz
|
||||||
Requires: perl-Nagios-Plugin
|
Requires: perl-Nagios-Plugin
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
Packager: Tomas Edwardsson <tommi@ok.is>
|
Packager: Gardar Thorsteinsson <gardar@ok.is>
|
||||||
|
|
||||||
|
|
||||||
%description
|
%description
|
||||||
@@ -20,6 +20,8 @@ Checks Brocade devices
|
|||||||
%setup -q
|
%setup -q
|
||||||
perl -pi -e "s|/usr/lib|%{_libdir}|g" check_brocade_env
|
perl -pi -e "s|/usr/lib|%{_libdir}|g" check_brocade_env
|
||||||
|
|
||||||
|
%global __requires_exclude %{?__requires_exclude:%__requires_exclude}|}^perl\\(utils\\)
|
||||||
|
|
||||||
%build
|
%build
|
||||||
|
|
||||||
|
|
||||||
@@ -36,6 +38,12 @@ rm -rf %{buildroot}
|
|||||||
%{_libdir}/nagios/plugins/*
|
%{_libdir}/nagios/plugins/*
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri May 09 2018 Gardar Thorsteinsson <gardar@ok.is> 0.0.5-2
|
||||||
|
- filter out perl-utils dep
|
||||||
|
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 0.0.5-1
|
||||||
|
-
|
||||||
|
|
||||||
* Mon Mar 12 2012 Pall Sigurdsson <palli@opensource.is> 0.0.4-1
|
* Mon Mar 12 2012 Pall Sigurdsson <palli@opensource.is> 0.0.4-1
|
||||||
- new package built with tito
|
- new package built with tito
|
||||||
|
|
||||||
|
|||||||
@@ -2,8 +2,8 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check CIFS shares
|
Summary: A Nagios plugin to check CIFS shares
|
||||||
Name: nagios-okplugin-cifs
|
Name: nagios-okplugin-cifs
|
||||||
Version: 1.0
|
Version: 1.1
|
||||||
Release: 1%{?dist}
|
Release: 2%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
URL: http://opensource.ok.is/trac/wiki/Nagios-OKPlugin-Brocade
|
URL: http://opensource.ok.is/trac/wiki/Nagios-OKPlugin-Brocade
|
||||||
@@ -11,7 +11,7 @@ Source0: http://opensource.ok.is/trac/browser/nagios-plugins/check_cifs/releases
|
|||||||
Requires: perl-Nagios-Plugin
|
Requires: perl-Nagios-Plugin
|
||||||
Requires: samba-client, krb5-workstation
|
Requires: samba-client, krb5-workstation
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
Packager: Tomas Edwardsson <tommi@ok.is>
|
Packager: Gardar Thorsteinsson <gardar@ok.is>
|
||||||
BuildArch: noarch
|
BuildArch: noarch
|
||||||
|
|
||||||
|
|
||||||
@@ -23,6 +23,8 @@ NTML authentication
|
|||||||
%setup -q
|
%setup -q
|
||||||
perl -pi -e "s|/usr/lib|%{_libdir}|g" check_cifs
|
perl -pi -e "s|/usr/lib|%{_libdir}|g" check_cifs
|
||||||
|
|
||||||
|
%global __requires_exclude %{?__requires_exclude:%__requires_exclude}|}^perl\\(utils\\)
|
||||||
|
|
||||||
%build
|
%build
|
||||||
|
|
||||||
|
|
||||||
@@ -39,6 +41,12 @@ rm -rf %{buildroot}
|
|||||||
%{_libdir}/nagios/plugins/*
|
%{_libdir}/nagios/plugins/*
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri May 09 2018 Gardar Thorsteinsson <gardar@ok.is> 1.1-2
|
||||||
|
- Filter out perl-utils dep
|
||||||
|
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 1.1-1
|
||||||
|
- Merge github.com:opinkerfi/misc (palli@opensource.is)
|
||||||
|
|
||||||
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.0-1
|
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.0-1
|
||||||
- version number of scripts bumped (palli@opensource.is)
|
- version number of scripts bumped (palli@opensource.is)
|
||||||
- Updates buildarch to noarch (tommi@tommi.org)
|
- Updates buildarch to noarch (tommi@tommi.org)
|
||||||
|
|||||||
59
check_cpu.py/nagios-okplugin-check_cpu.spec
Normal file
59
check_cpu.py/nagios-okplugin-check_cpu.spec
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
%define debug_package %{nil}
|
||||||
|
|
||||||
|
Summary: A Nagios plugin to check CPU on Linux servers
|
||||||
|
Name: nagios-okplugin-check_cpu
|
||||||
|
Version: 1.1
|
||||||
|
Release: 1%{?dist}
|
||||||
|
License: GPLv2+
|
||||||
|
Group: Applications/System
|
||||||
|
URL: https://github.com/opinkerfi/nagios-plugins/
|
||||||
|
Source0: https://github.com/opinkerfi/nagios-plugins/archive/%{name}-%{version}-%{release}.tar.gz
|
||||||
|
Requires: nagios-okplugin-common
|
||||||
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
|
Packager: Tomas Edwardsson <tommi@tommi.org>
|
||||||
|
BuildArch: noarch
|
||||||
|
|
||||||
|
%description
|
||||||
|
Check cpu states on line machines
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%setup -q
|
||||||
|
|
||||||
|
%build
|
||||||
|
|
||||||
|
|
||||||
|
%install
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
install -D -p -m 0755 okplugin_check_cpu %{buildroot}%{_libdir}/nagios/plugins/okplugin_check_cpu
|
||||||
|
install -D -p -m 0755 nrpe.d/okplugin_check_cpu.cfg %{buildroot}/etc/nrpe.d/okplugin_check_cpu.cfg
|
||||||
|
|
||||||
|
|
||||||
|
%clean
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
|
||||||
|
%post
|
||||||
|
/sbin/service nrpe reload
|
||||||
|
|
||||||
|
%files
|
||||||
|
%defattr(-,root,root,-)
|
||||||
|
%{_libdir}/nagios/plugins/*
|
||||||
|
%{_sysconfdir}/nrpe.d/*
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
%changelog
|
||||||
|
* Mon Jan 20 2014 Tomas Edwardsson <tommi@tommi.org> 1.1-1
|
||||||
|
- new package built with tito
|
||||||
|
|
||||||
|
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.0-1
|
||||||
|
- Version number bumped
|
||||||
|
- Updates buildarch to noarch (tommi@tommi.org)
|
||||||
|
|
||||||
|
* Mon Mar 12 2012 Pall Sigurdsson <palli@opensource.is> 0.3-1
|
||||||
|
- new package built with tito
|
||||||
|
|
||||||
|
* Thu Nov 25 2010 Pall Sigurdsson <palli@opensource.is> 0.1-2
|
||||||
|
- Nrpe config now ships with plugin by default
|
||||||
|
* Mon Mar 1 2010 Tomas Edwardsson <tommi@ok.is> 0.1-1
|
||||||
|
- Initial packaging
|
||||||
|
|
||||||
1
check_cpu.py/nrpe.d/okplugin_check_cpu.cfg
Normal file
1
check_cpu.py/nrpe.d/okplugin_check_cpu.cfg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
command[okplugin_check_cpu]=/usr/lib/nagios/plugins/okplugin_check_cpu
|
||||||
131
check_cpu.py/okplugin_check_cpu
Normal file
131
check_cpu.py/okplugin_check_cpu
Normal file
@@ -0,0 +1,131 @@
|
|||||||
|
#!/usr/bin/python
|
||||||
|
#
|
||||||
|
# Copyright 2014, Tomas Edwardsson
|
||||||
|
#
|
||||||
|
# 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 3 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.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
"""
|
||||||
|
Gathers information on cpu usage on a linux machine
|
||||||
|
|
||||||
|
It returns performance data for both the last 5 seconds and from last run.
|
||||||
|
"""
|
||||||
|
|
||||||
|
from pynag.Plugins import PluginHelper, ok, unknown
|
||||||
|
import os
|
||||||
|
import time
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
"""The main logic of the program"""
|
||||||
|
|
||||||
|
# See man proc and search for /proc/stat
|
||||||
|
stat_fields = ['cpu', 'user', 'nice', 'system', 'idle', 'iowait', 'irq',
|
||||||
|
'softirq', 'steal', 'guest', 'guest_nice']
|
||||||
|
|
||||||
|
pyplug = PluginHelper()
|
||||||
|
|
||||||
|
# Get the statistics from last run
|
||||||
|
old_stat = get_saved_stat()
|
||||||
|
|
||||||
|
# Get current state
|
||||||
|
stat = get_stat()
|
||||||
|
|
||||||
|
# Resample
|
||||||
|
time.sleep(5)
|
||||||
|
stat2 = get_stat()
|
||||||
|
|
||||||
|
try:
|
||||||
|
save_stat(stat)
|
||||||
|
except IOError, err:
|
||||||
|
pyplug.exit(unknown, "Unable to save cpu statistics: %s" % err)
|
||||||
|
|
||||||
|
|
||||||
|
# Calculate averages for the last few seconds
|
||||||
|
current_averages = diff_stats(stat2, stat)
|
||||||
|
for pos in range(len(current_averages)):
|
||||||
|
pyplug.add_metric(label=stat_fields[pos+1],
|
||||||
|
value=current_averages[pos],
|
||||||
|
uom="%")
|
||||||
|
|
||||||
|
# Calculate averages from last run
|
||||||
|
if old_stat:
|
||||||
|
last_run_avg = diff_stats(old_stat, stat)
|
||||||
|
for pos in range(len(current_averages)):
|
||||||
|
pyplug.add_metric(label=stat_fields[pos+1]+"_avg",
|
||||||
|
value=last_run_avg[pos],
|
||||||
|
uom="%")
|
||||||
|
|
||||||
|
pyplug.add_status(ok)
|
||||||
|
pyplug.add_summary("CPU load %.2f%%" % (100.0 - current_averages[3]))
|
||||||
|
pyplug.exit()
|
||||||
|
|
||||||
|
def diff_stats(older, newer):
|
||||||
|
"""Calculates the percentage between two stat arrays"""
|
||||||
|
if older:
|
||||||
|
diff = []
|
||||||
|
for pos in range(len(newer)):
|
||||||
|
diff.append(newer[pos] - older[pos])
|
||||||
|
averages = calc_avg(diff)
|
||||||
|
else:
|
||||||
|
averages = calc_avg(newer)
|
||||||
|
|
||||||
|
return averages
|
||||||
|
|
||||||
|
|
||||||
|
def remove_stale_state():
|
||||||
|
"""Removes the last state file if we have rebooted"""
|
||||||
|
|
||||||
|
try:
|
||||||
|
state_mtime = os.stat("/var/lib/nagios-okplugin/check_cpu").st_mtime
|
||||||
|
boot_time = os.stat("/proc/1").st_mtime
|
||||||
|
if state_mtime < boot_time:
|
||||||
|
os.unlink("/var/lib/nagios-okplugin/check_cpu")
|
||||||
|
except OSError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
return state_mtime
|
||||||
|
|
||||||
|
def calc_avg(stat):
|
||||||
|
"""Calculates the average of each int in array"""
|
||||||
|
stat_sum = sum(stat)
|
||||||
|
avg = []
|
||||||
|
for pos in range(len(stat)):
|
||||||
|
avg.append(float(stat[pos]) / stat_sum * 100)
|
||||||
|
return avg
|
||||||
|
|
||||||
|
def get_stat():
|
||||||
|
"""Fetches the first line from /proc/stat and returns the numbers"""
|
||||||
|
stat_fh = open("/proc/stat")
|
||||||
|
return [int(pos) for pos in stat_fh.readline().split()[1:]]
|
||||||
|
|
||||||
|
def get_saved_stat():
|
||||||
|
"""Fetches information about the last run to be able to do averages"""
|
||||||
|
|
||||||
|
remove_stale_state()
|
||||||
|
try:
|
||||||
|
stat_fh = open("/var/lib/nagios-okplugin/check_cpu")
|
||||||
|
except IOError:
|
||||||
|
return None
|
||||||
|
return [int(pos) for pos in stat_fh.readline().split()[1:]]
|
||||||
|
|
||||||
|
def save_stat(stat):
|
||||||
|
"""Save statistics to compare to in next run"""
|
||||||
|
stat_fh = open("/var/lib/nagios-okplugin/check_cpu", "w")
|
||||||
|
|
||||||
|
stat_fh.write("cpu " + " ".join([str(pos) for pos in stat]) + "\n")
|
||||||
|
stat_fh.close()
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
|
|
||||||
|
# vim: sts=4 expandtab
|
||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check CPU on Linux servers
|
Summary: A Nagios plugin to check CPU on Linux servers
|
||||||
Name: nagios-plugins-check_cpu
|
Name: nagios-plugins-check_cpu
|
||||||
Version: 1.0
|
Version: 2
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -45,6 +45,11 @@ rm -rf %{buildroot}
|
|||||||
|
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 2-1
|
||||||
|
- Added nrpe reload to post section (tommi@tommi.org)
|
||||||
|
- Merge github.com:opinkerfi/misc (palli@opensource.is)
|
||||||
|
- Added dependency on bc (palli@opensource.is)
|
||||||
|
|
||||||
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.0-1
|
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.0-1
|
||||||
- Version number bumped
|
- Version number bumped
|
||||||
- Updates buildarch to noarch (tommi@tommi.org)
|
- Updates buildarch to noarch (tommi@tommi.org)
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Summary: Nagios Plugins to monitor HP Dataprotector
|
Summary: Nagios Plugins to monitor HP Dataprotector
|
||||||
Name: nagios-okplugin-check_dataprotector
|
Name: nagios-okplugin-check_dataprotector
|
||||||
Version: 1.0.1
|
Version: 2
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -45,6 +45,10 @@ rm -rf %{buildroot}
|
|||||||
/etc/nrpe.d/check_dataprotector.cfg
|
/etc/nrpe.d/check_dataprotector.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 2-1
|
||||||
|
- removed warning threshold of 60 (palli@opensource.is)
|
||||||
|
- contrib removed from plugin path (palli@opensource.is)
|
||||||
|
|
||||||
* Mon Mar 12 2012 Pall Sigurdsson <palli@opensource.is> 1.0.1-1
|
* Mon Mar 12 2012 Pall Sigurdsson <palli@opensource.is> 1.0.1-1
|
||||||
- new package built with tito
|
- new package built with tito
|
||||||
|
|
||||||
|
|||||||
@@ -251,10 +251,10 @@ if ($ret > 1) {
|
|||||||
#
|
#
|
||||||
|
|
||||||
foreach my $l (@output) {
|
foreach my $l (@output) {
|
||||||
|
next if ($l =~ m/$opt_R/);
|
||||||
|
next if ($l !~ m/$opt_r/);
|
||||||
|
next if ($l =~ m/$exclude_re/);
|
||||||
if($l =~ /(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\%\s+([\/\w\d\.-]+)$/) {
|
if($l =~ /(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\%\s+([\/\w\d\.-]+)$/) {
|
||||||
next if ($l =~ m/$opt_R/);
|
|
||||||
next if ($l !~ m/$opt_r/);
|
|
||||||
next if ($l =~ m/$exclude_re/);
|
|
||||||
my ($s,$u,$f,$pu,$d) = ($1,$2,$3,$4,$5);
|
my ($s,$u,$f,$pu,$d) = ($1,$2,$3,$4,$5);
|
||||||
$alldisks{$d}->{pused} = $pu;
|
$alldisks{$d}->{pused} = $pu;
|
||||||
$alldisks{$d}->{pfree} = 100-$pu;
|
$alldisks{$d}->{pfree} = 100-$pu;
|
||||||
@@ -268,10 +268,10 @@ foreach my $l (@output) {
|
|||||||
# This is the output of df.exe on Windows
|
# This is the output of df.exe on Windows
|
||||||
#C:\ 9097126 6094081 3003045 67% argon-c (ntfs)
|
#C:\ 9097126 6094081 3003045 67% argon-c (ntfs)
|
||||||
else {
|
else {
|
||||||
if ($l =~ /(\w)\:\\\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\%\s+(.*)$/) {
|
|
||||||
next if ($l =~ m/$opt_R/);
|
next if ($l =~ m/$opt_R/);
|
||||||
next if ($l !~ m/$opt_r/);
|
next if ($l !~ m/$opt_r/);
|
||||||
next if ($l =~ m/$exclude_re/);
|
next if ($l =~ m/$exclude_re/);
|
||||||
|
if ($l =~ /(\w)\:\\\s+(\d+)\s+(\d+)\s+(\d+)\s+(\d+)\%\s+(.*)$/) {
|
||||||
my ($d,$s,$u,$f,$pu) = ("/$1",$2,$3,$4,$5);
|
my ($d,$s,$u,$f,$pu) = ("/$1",$2,$3,$4,$5);
|
||||||
$alldisks{$d}->{pused} = $pu;
|
$alldisks{$d}->{pused} = $pu;
|
||||||
$alldisks{$d}->{pfree} = 100-$pu;
|
$alldisks{$d}->{pfree} = 100-$pu;
|
||||||
@@ -324,7 +324,7 @@ if($opt_f) {
|
|||||||
if(defined($alldisks{$f})) {
|
if(defined($alldisks{$f})) {
|
||||||
$checkdisks{$f}=$alldisks{$f};
|
$checkdisks{$f}=$alldisks{$f};
|
||||||
}
|
}
|
||||||
} elsif ($f =~ /([\/\w\d]+)\:(\w+)\:(\w+)/) {
|
} elsif ($f =~ /^(.+?)\:(\w+)\:(\w+)/) {
|
||||||
if(defined($alldisks{$1})) {
|
if(defined($alldisks{$1})) {
|
||||||
$checkdisks{$1}=$alldisks{$1};
|
$checkdisks{$1}=$alldisks{$1};
|
||||||
updateRates($1,$2,$3,$checkdisks{$1}->{somme});
|
updateRates($1,$2,$3,$checkdisks{$1}->{somme});
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check disks via NRPE
|
Summary: A Nagios plugin to check disks via NRPE
|
||||||
Name: nagios-okplugin-check_disks
|
Name: nagios-okplugin-check_disks
|
||||||
Version: 1.0.4
|
Version: 1.0.7
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -40,6 +40,16 @@ rm -rf %{buildroot}
|
|||||||
%{_libdir}/nagios/plugins/check_disks.pl
|
%{_libdir}/nagios/plugins/check_disks.pl
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Wed Oct 29 2014 Tomas Edwardsson <tommi@tommi.org> 1.0.7-1
|
||||||
|
- Fix invalid regex if mountpoint has . in path (tommi@tommi.org)
|
||||||
|
- Regex filtering broke disk checks (tommi@tommi.org)
|
||||||
|
|
||||||
|
* Tue Mar 25 2014 Tomas Edwardsson <tommi@tommi.org> 1.0.6-1
|
||||||
|
- Bumped version
|
||||||
|
|
||||||
|
* Tue Mar 25 2014 Tomas Edwardsson <tommi@tommi.org> 1.0.5-1
|
||||||
|
- Added support for inodes (tryggvi@linux.is)
|
||||||
|
|
||||||
* Sat Mar 02 2013 Tryggvi Farestveit <tryggvi@linux.is> 1.0.4-1
|
* Sat Mar 02 2013 Tryggvi Farestveit <tryggvi@linux.is> 1.0.4-1
|
||||||
- Added support for inodes
|
- Added support for inodes
|
||||||
|
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check HP EVA Disk Systems
|
Summary: A Nagios plugin to check HP EVA Disk Systems
|
||||||
Name: nagios-okplugin-check_eva
|
Name: nagios-okplugin-check_eva
|
||||||
Version: 1.0.2
|
Version: 2
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -40,6 +40,22 @@ rm -rf %{buildroot}
|
|||||||
/etc/nrpe.d/check_eva.cfg
|
/etc/nrpe.d/check_eva.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 2-1
|
||||||
|
- Merge pull request #10 from gitmopp/patch-2 (palli-github@minor.is)
|
||||||
|
- bug in for loop. Looped only once (mopp@gmx.net)
|
||||||
|
- Fixed output to be more compatible (mopp@gmx.net)
|
||||||
|
- check_eva new Make sure --timeout is an integer (palli@opensource.is)
|
||||||
|
- check_eva new command line option --timeout (palli@opensource.is)
|
||||||
|
- check_eva Fix undefined fix typos (palli@opensource.is)
|
||||||
|
- PEP8 cleanup (palli@opensource.is)
|
||||||
|
- merged (palli@opensource.is)
|
||||||
|
- check_eva - minor bugfixes (palli@opensource.is)
|
||||||
|
- check_eva.py more code cleanup with pycharm inspections (palli@opensource.is)
|
||||||
|
- check_eva.py - Make code more readable (palli@opensource.is)
|
||||||
|
- convert from tabs to spaces (palli@opensource.is)
|
||||||
|
- check_eva - fix mixed tab/spaces (palli@opensource.is)
|
||||||
|
- Update check_eva.py (sander.grendelman@gmail.com)
|
||||||
|
|
||||||
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.0.2-1
|
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.0.2-1
|
||||||
- changed sssu subcommands from being singlequoted to doublequoted for windows
|
- changed sssu subcommands from being singlequoted to doublequoted for windows
|
||||||
compatibility (palli@opensource.is)
|
compatibility (palli@opensource.is)
|
||||||
|
|||||||
23
check_firewall_active/check_firewall_active.sh
Executable file
23
check_firewall_active/check_firewall_active.sh
Executable file
@@ -0,0 +1,23 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
EXIT_OK=0
|
||||||
|
EXIT_WARN=1
|
||||||
|
EXIT_CRIT=2
|
||||||
|
|
||||||
|
PATH=/sbin:/usr/sbin:$PATH
|
||||||
|
|
||||||
|
if [ "$(id -u)" != "0" ]; then
|
||||||
|
echo "This script must be run as root" 1>&2
|
||||||
|
exit $EXIT_CRIT
|
||||||
|
fi
|
||||||
|
|
||||||
|
blocks=$(iptables -L -v -n | egrep 'REJECT|DROP' | wc -l)
|
||||||
|
|
||||||
|
if [ $blocks -eq 0 ]; then
|
||||||
|
echo "CRITICAL: No firewall detected"
|
||||||
|
exit $EXIT_CRIT
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "OK: Firewall is active"
|
||||||
|
exit $EXIT_OK
|
||||||
|
|
||||||
@@ -0,0 +1,52 @@
|
|||||||
|
%define debug_package %{nil}
|
||||||
|
|
||||||
|
Summary: A Nagios plugin to check if iptables are actually enforcing rules
|
||||||
|
Name: nagios-okplugin-check_firewall_active
|
||||||
|
Version: 1.0.2
|
||||||
|
Release: 1%{?dist}
|
||||||
|
License: GPLv2+
|
||||||
|
Group: Applications/System
|
||||||
|
URL: https://github.com/opinkerfi/nagios-plugins/issues
|
||||||
|
Source0: http://opensource.ok.is/trac/browser/nagios-plugins/check_firewall_active/releases/nagios-okplugin-check_firewall_active-%{version}.tar.gz
|
||||||
|
Requires: nagios-nrpe
|
||||||
|
Requires: iptables
|
||||||
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
|
Packager: Richard Allen <ra@ok.is>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
%description
|
||||||
|
A Nagios plugin to check if iptables are actually enforcing rules
|
||||||
|
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%setup -q
|
||||||
|
#perl -pi -e "s|/usr/lib64|%{_libdir}|g" nrpe.d/check_firewall_active.cfg
|
||||||
|
|
||||||
|
%build
|
||||||
|
|
||||||
|
|
||||||
|
%install
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
install -D -p -m 0755 check_firewall_active.sh %{buildroot}%{_libdir}/nagios/plugins/check_firewall_active.sh
|
||||||
|
install -D -p -m 0755 nrpe.d/check_firewall_active.cfg %{buildroot}/etc/nrpe.d/check_firewall_active.cfg
|
||||||
|
install -D -p -m 0644 sudoers.d/check_firewall_active %{buildroot}/etc/sudoers.d/check_firewall_active
|
||||||
|
|
||||||
|
%clean
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
|
||||||
|
%files
|
||||||
|
%defattr(-,root,root,-)
|
||||||
|
#%doc README LICENSE
|
||||||
|
%{_libdir}/nagios/plugins/*
|
||||||
|
/etc/nrpe.d/check_firewall_active.cfg
|
||||||
|
/etc/sudoers.d/check_firewall_active
|
||||||
|
|
||||||
|
%post
|
||||||
|
restorecon -v %{_libdir}/nagios/plugins/check_firewall_active.sh /etc/nrpe.d/check_firewall_active.cfg /etc/sudoers.d/check_firewall_active
|
||||||
|
|
||||||
|
%changelog
|
||||||
|
* Thu Dec 21 2016 Gardar Thorsteinsson <gardart@gmail.com> 1.0.1-1
|
||||||
|
* Thu Dec 21 2016 Gardar Thorsteinsson <gardart@gmail.com> 1.0.0-3
|
||||||
|
* Thu Dec 20 2016 Richard Allen <ra@ok.is> 0.1-1
|
||||||
|
- Initial packaging
|
||||||
3
check_firewall_active/nrpe.d/check_firewall_active.cfg
Normal file
3
check_firewall_active/nrpe.d/check_firewall_active.cfg
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
|
||||||
|
|
||||||
|
command[check_firewall_active]=sudo /usr/lib64/nagios/plugins/check_firewall_active.sh
|
||||||
2
check_firewall_active/sudoers.d/check_firewall_active
Normal file
2
check_firewall_active/sudoers.d/check_firewall_active
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
Defaults:nrpe !requiretty
|
||||||
|
nrpe ALL = (root) NOPASSWD: /usr/lib64/nagios/plugins/check_firewall_active.sh
|
||||||
@@ -274,6 +274,9 @@ def check_logicaldisks():
|
|||||||
ld_status = check(i, 'Status')
|
ld_status = check(i, 'Status')
|
||||||
status = max(status, ld_status)
|
status = max(status, ld_status)
|
||||||
|
|
||||||
|
if i.get('Status') == 'Failed':
|
||||||
|
status = max(status, critical)
|
||||||
|
|
||||||
mount_point = i['Mount Points']
|
mount_point = i['Mount Points']
|
||||||
add_long("- %s (%s) = %s" % (i['name'], mount_point, state[ld_status]))
|
add_long("- %s (%s) = %s" % (i['name'], mount_point, state[ld_status]))
|
||||||
add_summary(". ")
|
add_summary(". ")
|
||||||
|
|||||||
@@ -2,8 +2,8 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check HP Array with hpacucli
|
Summary: A Nagios plugin to check HP Array with hpacucli
|
||||||
Name: nagios-okplugin-check_hpacucli
|
Name: nagios-okplugin-check_hpacucli
|
||||||
Version: 1.2
|
Version: 2
|
||||||
Release: 2%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
URL: http://opensource.is/trac/wiki/check_hpacucli
|
URL: http://opensource.is/trac/wiki/check_hpacucli
|
||||||
@@ -28,7 +28,7 @@ perl -pi -e "s|/usr/lib64|%{_libdir}|g" sudoers.d/*
|
|||||||
rm -rf %{buildroot}
|
rm -rf %{buildroot}
|
||||||
install -D -p -m 0755 check_hpacucli.py %{buildroot}%{_libdir}/nagios/plugins/check_hpacucli.py
|
install -D -p -m 0755 check_hpacucli.py %{buildroot}%{_libdir}/nagios/plugins/check_hpacucli.py
|
||||||
install -D -p -m 0755 nrpe.d/check_hpacucli.cfg %{buildroot}/etc/nrpe.d/check_hpacucli.cfg
|
install -D -p -m 0755 nrpe.d/check_hpacucli.cfg %{buildroot}/etc/nrpe.d/check_hpacucli.cfg
|
||||||
install -D -p -m 0755 sudoers.d/check_hpacucli %{buildroot}/etc/sudoers.d/check_hpacucli
|
install -D -p -m 0440 sudoers.d/check_hpacucli %{buildroot}/etc/sudoers.d/check_hpacucli
|
||||||
|
|
||||||
%clean
|
%clean
|
||||||
rm -rf %{buildroot}
|
rm -rf %{buildroot}
|
||||||
@@ -41,6 +41,17 @@ rm -rf %{buildroot}
|
|||||||
/etc/sudoers.d/check_hpacucli
|
/etc/sudoers.d/check_hpacucli
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 2-1
|
||||||
|
- check_hpacucli.py - fix typo in hpacucli command (palli@opensource.is)
|
||||||
|
- check_hpacucli.py: pep8 cleanup (palli@opensource.is)
|
||||||
|
- check_hpacucli - fix tab indentation (palli@opensource.is)
|
||||||
|
- check_hpacucli: ignore hpacucli output that starts with "Note:"
|
||||||
|
(palli@opensource.is)
|
||||||
|
- sudoers.d added to install (you@example.com)
|
||||||
|
- dummy commit (you@example.com)
|
||||||
|
- dummy commit (you@example.com)
|
||||||
|
- Add sudoers support to check_hpacucli (palli@opensource.is)
|
||||||
|
|
||||||
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.2-2
|
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.2-2
|
||||||
- version number of scripts bumped (palli@opensource.is)
|
- version number of scripts bumped (palli@opensource.is)
|
||||||
|
|
||||||
|
|||||||
@@ -1 +1,2 @@
|
|||||||
|
Defaults:nrpe !requiretty
|
||||||
nrpe ALL=(ALL) NOPASSWD: /usr/lib64/nagios/plugins/check_hpacucli.py
|
nrpe ALL=(ALL) NOPASSWD: /usr/lib64/nagios/plugins/check_hpacucli.py
|
||||||
|
|||||||
@@ -81,7 +81,7 @@ check_raid()
|
|||||||
{
|
{
|
||||||
raid_ok=`cat $TEMPFILE |grep -i ok|wc -l`
|
raid_ok=`cat $TEMPFILE |grep -i ok|wc -l`
|
||||||
raid_warning=`cat $TEMPFILE|grep -i -E 'rebuild|predictive' |wc -l`
|
raid_warning=`cat $TEMPFILE|grep -i -E 'rebuild|predictive' |wc -l`
|
||||||
raid_critical_1=`cat $TEMPFILE|grep -i 'failed|recovery' | wc -l`
|
raid_critical_1=`cat $TEMPFILE|grep -i -E 'failed|recovery' | wc -l`
|
||||||
|
|
||||||
err_check=`expr $raid_ok + $raid_warning + $raid_critical_1 `
|
err_check=`expr $raid_ok + $raid_warning + $raid_critical_1 `
|
||||||
|
|
||||||
@@ -133,7 +133,7 @@ case "$1" in
|
|||||||
exit 0
|
exit 0
|
||||||
;;
|
;;
|
||||||
--all)
|
--all)
|
||||||
controllers=`sudo -u root hpacucli controller all show | sed 's/.*Slot \([0-9]*\).*/\1/'`
|
controllers=`sudo -u root $HPACUCLI controller all show | sed 's/.*Slot \([0-9]*\).*/\1/'`
|
||||||
for i in $controllers ; do sudo -u root $HPACUCLI controller slot=$i pd all show status;done > $TEMPFILE
|
for i in $controllers ; do sudo -u root $HPACUCLI controller slot=$i pd all show status;done > $TEMPFILE
|
||||||
check_raid
|
check_raid
|
||||||
;;
|
;;
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check HP Hardware Status
|
Summary: A Nagios plugin to check HP Hardware Status
|
||||||
Name: nagios-okplugin-check_hpasm
|
Name: nagios-okplugin-check_hpasm
|
||||||
Version: 4.1.2
|
Version: 4.1.4
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -45,5 +45,11 @@ rm -rf %{buildroot}
|
|||||||
/etc/nrpe.d/check_hpasm.cfg
|
/etc/nrpe.d/check_hpasm.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri Oct 03 2014 Tomas Edwardsson <tommi@tommi.org> 4.1.4-1
|
||||||
|
- hpasm invalid nrpe check command name (tommi@tommi.org)
|
||||||
|
|
||||||
|
* Thu May 15 2014 Tomas Edwardsson <tommi@tommi.org> 4.1.3-1
|
||||||
|
- new package built with tito
|
||||||
|
|
||||||
* Tue Jun 4 2013 Pall Sigurdsson <palli@opensource.is> 4.1.2-1
|
* Tue Jun 4 2013 Pall Sigurdsson <palli@opensource.is> 4.1.2-1
|
||||||
- Initial packaging
|
- Initial packaging
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
|
|
||||||
|
|
||||||
command[check_updates]=sudo /usr/lib/nagios/plugins/check_hpasm
|
command[check_hpasm]=sudo /usr/lib/nagios/plugins/check_hpasm
|
||||||
|
|||||||
341
check_hpssacli/LICENSE
Normal file
341
check_hpssacli/LICENSE
Normal file
@@ -0,0 +1,341 @@
|
|||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
Version 2, June 1991
|
||||||
|
|
||||||
|
Copyright (C) 1989, 1991 Free Software Foundation, Inc.
|
||||||
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
Preamble
|
||||||
|
|
||||||
|
The licenses for most software are designed to take away your
|
||||||
|
freedom to share and change it. By contrast, the GNU General Public
|
||||||
|
License is intended to guarantee your freedom to share and change free
|
||||||
|
software--to make sure the software is free for all its users. This
|
||||||
|
General Public License applies to most of the Free Software
|
||||||
|
Foundation's software and to any other program whose authors commit to
|
||||||
|
using it. (Some other Free Software Foundation software is covered by
|
||||||
|
the GNU Library General Public License instead.) You can apply it to
|
||||||
|
your programs, too.
|
||||||
|
|
||||||
|
When we speak of free software, we are referring to freedom, not
|
||||||
|
price. Our General Public Licenses are designed to make sure that you
|
||||||
|
have the freedom to distribute copies of free software (and charge for
|
||||||
|
this service if you wish), that you receive source code or can get it
|
||||||
|
if you want it, that you can change the software or use pieces of it
|
||||||
|
in new free programs; and that you know you can do these things.
|
||||||
|
|
||||||
|
To protect your rights, we need to make restrictions that forbid
|
||||||
|
anyone to deny you these rights or to ask you to surrender the rights.
|
||||||
|
These restrictions translate to certain responsibilities for you if you
|
||||||
|
distribute copies of the software, or if you modify it.
|
||||||
|
|
||||||
|
For example, if you distribute copies of such a program, whether
|
||||||
|
gratis or for a fee, you must give the recipients all the rights that
|
||||||
|
you have. You must make sure that they, too, receive or can get the
|
||||||
|
source code. And you must show them these terms so they know their
|
||||||
|
rights.
|
||||||
|
|
||||||
|
We protect your rights with two steps: (1) copyright the software, and
|
||||||
|
(2) offer you this license which gives you legal permission to copy,
|
||||||
|
distribute and/or modify the software.
|
||||||
|
|
||||||
|
Also, for each author's protection and ours, we want to make certain
|
||||||
|
that everyone understands that there is no warranty for this free
|
||||||
|
software. If the software is modified by someone else and passed on, we
|
||||||
|
want its recipients to know that what they have is not the original, so
|
||||||
|
that any problems introduced by others will not reflect on the original
|
||||||
|
authors' reputations.
|
||||||
|
|
||||||
|
Finally, any free program is threatened constantly by software
|
||||||
|
patents. We wish to avoid the danger that redistributors of a free
|
||||||
|
program will individually obtain patent licenses, in effect making the
|
||||||
|
program proprietary. To prevent this, we have made it clear that any
|
||||||
|
patent must be licensed for everyone's free use or not licensed at all.
|
||||||
|
|
||||||
|
The precise terms and conditions for copying, distribution and
|
||||||
|
modification follow.
|
||||||
|
|
||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||||
|
|
||||||
|
0. This License applies to any program or other work which contains
|
||||||
|
a notice placed by the copyright holder saying it may be distributed
|
||||||
|
under the terms of this General Public License. The "Program", below,
|
||||||
|
refers to any such program or work, and a "work based on the Program"
|
||||||
|
means either the Program or any derivative work under copyright law:
|
||||||
|
that is to say, a work containing the Program or a portion of it,
|
||||||
|
either verbatim or with modifications and/or translated into another
|
||||||
|
language. (Hereinafter, translation is included without limitation in
|
||||||
|
the term "modification".) Each licensee is addressed as "you".
|
||||||
|
|
||||||
|
Activities other than copying, distribution and modification are not
|
||||||
|
covered by this License; they are outside its scope. The act of
|
||||||
|
running the Program is not restricted, and the output from the Program
|
||||||
|
is covered only if its contents constitute a work based on the
|
||||||
|
Program (independent of having been made by running the Program).
|
||||||
|
Whether that is true depends on what the Program does.
|
||||||
|
|
||||||
|
1. You may copy and distribute verbatim copies of the Program's
|
||||||
|
source code as you receive it, in any medium, provided that you
|
||||||
|
conspicuously and appropriately publish on each copy an appropriate
|
||||||
|
copyright notice and disclaimer of warranty; keep intact all the
|
||||||
|
notices that refer to this License and to the absence of any warranty;
|
||||||
|
and give any other recipients of the Program a copy of this License
|
||||||
|
along with the Program.
|
||||||
|
|
||||||
|
You may charge a fee for the physical act of transferring a copy, and
|
||||||
|
you may at your option offer warranty protection in exchange for a fee.
|
||||||
|
|
||||||
|
2. You may modify your copy or copies of the Program or any portion
|
||||||
|
of it, thus forming a work based on the Program, and copy and
|
||||||
|
distribute such modifications or work under the terms of Section 1
|
||||||
|
above, provided that you also meet all of these conditions:
|
||||||
|
|
||||||
|
a) You must cause the modified files to carry prominent notices
|
||||||
|
stating that you changed the files and the date of any change.
|
||||||
|
|
||||||
|
b) You must cause any work that you distribute or publish, that in
|
||||||
|
whole or in part contains or is derived from the Program or any
|
||||||
|
part thereof, to be licensed as a whole at no charge to all third
|
||||||
|
parties under the terms of this License.
|
||||||
|
|
||||||
|
c) If the modified program normally reads commands interactively
|
||||||
|
when run, you must cause it, when started running for such
|
||||||
|
interactive use in the most ordinary way, to print or display an
|
||||||
|
announcement including an appropriate copyright notice and a
|
||||||
|
notice that there is no warranty (or else, saying that you provide
|
||||||
|
a warranty) and that users may redistribute the program under
|
||||||
|
these conditions, and telling the user how to view a copy of this
|
||||||
|
License. (Exception: if the Program itself is interactive but
|
||||||
|
does not normally print such an announcement, your work based on
|
||||||
|
the Program is not required to print an announcement.)
|
||||||
|
|
||||||
|
These requirements apply to the modified work as a whole. If
|
||||||
|
identifiable sections of that work are not derived from the Program,
|
||||||
|
and can be reasonably considered independent and separate works in
|
||||||
|
themselves, then this License, and its terms, do not apply to those
|
||||||
|
sections when you distribute them as separate works. But when you
|
||||||
|
distribute the same sections as part of a whole which is a work based
|
||||||
|
on the Program, the distribution of the whole must be on the terms of
|
||||||
|
this License, whose permissions for other licensees extend to the
|
||||||
|
entire whole, and thus to each and every part regardless of who wrote it.
|
||||||
|
|
||||||
|
Thus, it is not the intent of this section to claim rights or contest
|
||||||
|
your rights to work written entirely by you; rather, the intent is to
|
||||||
|
exercise the right to control the distribution of derivative or
|
||||||
|
collective works based on the Program.
|
||||||
|
|
||||||
|
In addition, mere aggregation of another work not based on the Program
|
||||||
|
with the Program (or with a work based on the Program) on a volume of
|
||||||
|
a storage or distribution medium does not bring the other work under
|
||||||
|
the scope of this License.
|
||||||
|
|
||||||
|
3. You may copy and distribute the Program (or a work based on it,
|
||||||
|
under Section 2) in object code or executable form under the terms of
|
||||||
|
Sections 1 and 2 above provided that you also do one of the following:
|
||||||
|
|
||||||
|
a) Accompany it with the complete corresponding machine-readable
|
||||||
|
source code, which must be distributed under the terms of Sections
|
||||||
|
1 and 2 above on a medium customarily used for software interchange; or,
|
||||||
|
|
||||||
|
b) Accompany it with a written offer, valid for at least three
|
||||||
|
years, to give any third party, for a charge no more than your
|
||||||
|
cost of physically performing source distribution, a complete
|
||||||
|
machine-readable copy of the corresponding source code, to be
|
||||||
|
distributed under the terms of Sections 1 and 2 above on a medium
|
||||||
|
customarily used for software interchange; or,
|
||||||
|
|
||||||
|
c) Accompany it with the information you received as to the offer
|
||||||
|
to distribute corresponding source code. (This alternative is
|
||||||
|
allowed only for noncommercial distribution and only if you
|
||||||
|
received the program in object code or executable form with such
|
||||||
|
an offer, in accord with Subsection b above.)
|
||||||
|
|
||||||
|
The source code for a work means the preferred form of the work for
|
||||||
|
making modifications to it. For an executable work, complete source
|
||||||
|
code means all the source code for all modules it contains, plus any
|
||||||
|
associated interface definition files, plus the scripts used to
|
||||||
|
control compilation and installation of the executable. However, as a
|
||||||
|
special exception, the source code distributed need not include
|
||||||
|
anything that is normally distributed (in either source or binary
|
||||||
|
form) with the major components (compiler, kernel, and so on) of the
|
||||||
|
operating system on which the executable runs, unless that component
|
||||||
|
itself accompanies the executable.
|
||||||
|
|
||||||
|
If distribution of executable or object code is made by offering
|
||||||
|
access to copy from a designated place, then offering equivalent
|
||||||
|
access to copy the source code from the same place counts as
|
||||||
|
distribution of the source code, even though third parties are not
|
||||||
|
compelled to copy the source along with the object code.
|
||||||
|
|
||||||
|
4. You may not copy, modify, sublicense, or distribute the Program
|
||||||
|
except as expressly provided under this License. Any attempt
|
||||||
|
otherwise to copy, modify, sublicense or distribute the Program is
|
||||||
|
void, and will automatically terminate your rights under this License.
|
||||||
|
However, parties who have received copies, or rights, from you under
|
||||||
|
this License will not have their licenses terminated so long as such
|
||||||
|
parties remain in full compliance.
|
||||||
|
|
||||||
|
5. You are not required to accept this License, since you have not
|
||||||
|
signed it. However, nothing else grants you permission to modify or
|
||||||
|
distribute the Program or its derivative works. These actions are
|
||||||
|
prohibited by law if you do not accept this License. Therefore, by
|
||||||
|
modifying or distributing the Program (or any work based on the
|
||||||
|
Program), you indicate your acceptance of this License to do so, and
|
||||||
|
all its terms and conditions for copying, distributing or modifying
|
||||||
|
the Program or works based on it.
|
||||||
|
|
||||||
|
6. Each time you redistribute the Program (or any work based on the
|
||||||
|
Program), the recipient automatically receives a license from the
|
||||||
|
original licensor to copy, distribute or modify the Program subject to
|
||||||
|
these terms and conditions. You may not impose any further
|
||||||
|
restrictions on the recipients' exercise of the rights granted herein.
|
||||||
|
You are not responsible for enforcing compliance by third parties to
|
||||||
|
this License.
|
||||||
|
|
||||||
|
7. If, as a consequence of a court judgment or allegation of patent
|
||||||
|
infringement or for any other reason (not limited to patent issues),
|
||||||
|
conditions are imposed on you (whether by court order, agreement or
|
||||||
|
otherwise) that contradict the conditions of this License, they do not
|
||||||
|
excuse you from the conditions of this License. If you cannot
|
||||||
|
distribute so as to satisfy simultaneously your obligations under this
|
||||||
|
License and any other pertinent obligations, then as a consequence you
|
||||||
|
may not distribute the Program at all. For example, if a patent
|
||||||
|
license would not permit royalty-free redistribution of the Program by
|
||||||
|
all those who receive copies directly or indirectly through you, then
|
||||||
|
the only way you could satisfy both it and this License would be to
|
||||||
|
refrain entirely from distribution of the Program.
|
||||||
|
|
||||||
|
If any portion of this section is held invalid or unenforceable under
|
||||||
|
any particular circumstance, the balance of the section is intended to
|
||||||
|
apply and the section as a whole is intended to apply in other
|
||||||
|
circumstances.
|
||||||
|
|
||||||
|
It is not the purpose of this section to induce you to infringe any
|
||||||
|
patents or other property right claims or to contest validity of any
|
||||||
|
such claims; this section has the sole purpose of protecting the
|
||||||
|
integrity of the free software distribution system, which is
|
||||||
|
implemented by public license practices. Many people have made
|
||||||
|
generous contributions to the wide range of software distributed
|
||||||
|
through that system in reliance on consistent application of that
|
||||||
|
system; it is up to the author/donor to decide if he or she is willing
|
||||||
|
to distribute software through any other system and a licensee cannot
|
||||||
|
impose that choice.
|
||||||
|
|
||||||
|
This section is intended to make thoroughly clear what is believed to
|
||||||
|
be a consequence of the rest of this License.
|
||||||
|
|
||||||
|
8. If the distribution and/or use of the Program is restricted in
|
||||||
|
certain countries either by patents or by copyrighted interfaces, the
|
||||||
|
original copyright holder who places the Program under this License
|
||||||
|
may add an explicit geographical distribution limitation excluding
|
||||||
|
those countries, so that distribution is permitted only in or among
|
||||||
|
countries not thus excluded. In such case, this License incorporates
|
||||||
|
the limitation as if written in the body of this License.
|
||||||
|
|
||||||
|
9. The Free Software Foundation may publish revised and/or new versions
|
||||||
|
of the General Public License from time to time. Such new versions will
|
||||||
|
be similar in spirit to the present version, but may differ in detail to
|
||||||
|
address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the Program
|
||||||
|
specifies a version number of this License which applies to it and "any
|
||||||
|
later version", you have the option of following the terms and conditions
|
||||||
|
either of that version or of any later version published by the Free
|
||||||
|
Software Foundation. If the Program does not specify a version number of
|
||||||
|
this License, you may choose any version ever published by the Free Software
|
||||||
|
Foundation.
|
||||||
|
|
||||||
|
10. If you wish to incorporate parts of the Program into other free
|
||||||
|
programs whose distribution conditions are different, write to the author
|
||||||
|
to ask for permission. For software which is copyrighted by the Free
|
||||||
|
Software Foundation, write to the Free Software Foundation; we sometimes
|
||||||
|
make exceptions for this. Our decision will be guided by the two goals
|
||||||
|
of preserving the free status of all derivatives of our free software and
|
||||||
|
of promoting the sharing and reuse of software generally.
|
||||||
|
|
||||||
|
NO WARRANTY
|
||||||
|
|
||||||
|
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
|
||||||
|
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
|
||||||
|
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
|
||||||
|
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
|
||||||
|
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||||
|
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
|
||||||
|
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
|
||||||
|
REPAIR OR CORRECTION.
|
||||||
|
|
||||||
|
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||||
|
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
|
||||||
|
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
|
||||||
|
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
|
||||||
|
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
|
||||||
|
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
|
||||||
|
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
|
||||||
|
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGES.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
|
||||||
|
How to Apply These Terms to Your New Programs
|
||||||
|
|
||||||
|
If you develop a new program, and you want it to be of the greatest
|
||||||
|
possible use to the public, the best way to achieve this is to make it
|
||||||
|
free software which everyone can redistribute and change under these terms.
|
||||||
|
|
||||||
|
To do so, attach the following notices to the program. It is safest
|
||||||
|
to attach them to the start of each source file to most effectively
|
||||||
|
convey the exclusion of warranty; and each file should have at least
|
||||||
|
the "copyright" line and a pointer to where the full notice is found.
|
||||||
|
|
||||||
|
<one line to give the program's name and a brief idea of what it does.>
|
||||||
|
Copyright (C) 19yy <name of author>
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
|
||||||
|
|
||||||
|
Also add information on how to contact you by electronic and paper mail.
|
||||||
|
|
||||||
|
If the program is interactive, make it output a short notice like this
|
||||||
|
when it starts in an interactive mode:
|
||||||
|
|
||||||
|
Gnomovision version 69, Copyright (C) 19yy name of author
|
||||||
|
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||||
|
This is free software, and you are welcome to redistribute it
|
||||||
|
under certain conditions; type `show c' for details.
|
||||||
|
|
||||||
|
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||||
|
parts of the General Public License. Of course, the commands you use may
|
||||||
|
be called something other than `show w' and `show c'; they could even be
|
||||||
|
mouse-clicks or menu items--whatever suits your program.
|
||||||
|
|
||||||
|
You should also get your employer (if you work as a programmer) or your
|
||||||
|
school, if any, to sign a "copyright disclaimer" for the program, if
|
||||||
|
necessary. Here is a sample; alter the names:
|
||||||
|
|
||||||
|
Yoyodyne, Inc., hereby disclaims all copyright interest in the program
|
||||||
|
`Gnomovision' (which makes passes at compilers) written by James Hacker.
|
||||||
|
|
||||||
|
<signature of Ty Coon>, 1 April 1989
|
||||||
|
Ty Coon, President of Vice
|
||||||
|
|
||||||
|
This General Public License does not permit incorporating your program into
|
||||||
|
proprietary programs. If your program is a subroutine library, you may
|
||||||
|
consider it more useful to permit linking proprietary applications with the
|
||||||
|
library. If this is what you want to do, use the GNU Library General
|
||||||
|
Public License instead of this License.
|
||||||
53
check_hpssacli/README
Normal file
53
check_hpssacli/README
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
= check_hpssacli =
|
||||||
|
Checks the raid status on a HP Array using hpssacli. to check the following:
|
||||||
|
|
||||||
|
* Controller Status
|
||||||
|
* Controller Cache Status
|
||||||
|
* Logical disk health (raid status)
|
||||||
|
* Physical disk health
|
||||||
|
|
||||||
|
== Download ==
|
||||||
|
check_hpssacli.py depends on the hpssacli binary which comes with the HP Proliant Support Pack (PSP). The PSP can be downloaded [http://downloads.linux.hp.com/SDR/downloads/ProLiantSupportPack here].
|
||||||
|
|
||||||
|
You can get check_hpacucly.py directly from our subversion repo [http://opensource.is/trac/browser/nagios-plugins/check_hpssacli/trunk here]
|
||||||
|
|
||||||
|
== help page ==
|
||||||
|
{{{
|
||||||
|
# python check_hpssacli.py --help
|
||||||
|
check_hpssacli version 1.0
|
||||||
|
This plugin checks HP Array with the hpssacli command
|
||||||
|
|
||||||
|
Usage: check_hpssacli.py
|
||||||
|
Usage: check_hpssacli.py [--help]
|
||||||
|
Usage: check_hpssacli.py [--version]
|
||||||
|
Usage: check_hpssacli.py [--path </path/to/hpssacli>]
|
||||||
|
Usage: check_hpssacli.py [--no-perfdata]
|
||||||
|
Usage: check_hpssacli.py [--no-longoutput]
|
||||||
|
|
||||||
|
|
||||||
|
}}}
|
||||||
|
|
||||||
|
== Example output ==
|
||||||
|
{{{
|
||||||
|
# ./check_hparray --all
|
||||||
|
OK - Found 1 controllers, 2 logicaldisks. 8 physicaldisks. |
|
||||||
|
|
||||||
|
Smart Array P400 in Slot 1
|
||||||
|
- Controller Status: OK (sn: P61620F9VV6FX2)
|
||||||
|
- Cache Status: OK (sn: PA82C0H9VV4695)
|
||||||
|
|
||||||
|
Checking logical Disks:
|
||||||
|
- Logical Drive: 1 (/boot 101 MB) = OK
|
||||||
|
- Logical Drive: 2 (None) = OK
|
||||||
|
|
||||||
|
Checking Physical Disks:
|
||||||
|
- physicaldrive 2I:1:1, SAS, 146 GB = OK
|
||||||
|
- physicaldrive 2I:1:2, SAS, 146 GB = OK
|
||||||
|
- physicaldrive 1I:1:5, SAS, 146 GB = OK
|
||||||
|
- physicaldrive 1I:1:6, SAS, 146 GB = OK
|
||||||
|
- physicaldrive 1I:1:7, SAS, 146 GB = OK
|
||||||
|
- physicaldrive 1I:1:8, SAS, 146 GB = OK
|
||||||
|
- physicaldrive 2I:1:3, SAS, 146 GB = OK
|
||||||
|
- physicaldrive 2I:1:4, SAS, 146 GB = OK
|
||||||
|
}}}
|
||||||
|
|
||||||
362
check_hpssacli/check_hpssacli.py
Normal file
362
check_hpssacli/check_hpssacli.py
Normal file
@@ -0,0 +1,362 @@
|
|||||||
|
#!/usr/bin/python
|
||||||
|
#
|
||||||
|
# Copyright 2019, Gardar Thorsteinsson <gardar@ok.is>
|
||||||
|
#
|
||||||
|
# check_hpssacli.py 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 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# check_hpssacli.py 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.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
# About this script
|
||||||
|
#
|
||||||
|
# This script will check the status of Smart Array Raid Controller
|
||||||
|
# You need the hpssacli binary in path (/usr/sbin/hpssacli is a good place)
|
||||||
|
# hpssacli comes with the Proliant Support Pack (PSP) from HP
|
||||||
|
|
||||||
|
debugging = False
|
||||||
|
|
||||||
|
# No real need to change anything below here
|
||||||
|
version = "1.1"
|
||||||
|
ok = 0
|
||||||
|
warning = 1
|
||||||
|
critical = 2
|
||||||
|
unknown = 3
|
||||||
|
not_present = -1
|
||||||
|
nagios_status = -1
|
||||||
|
|
||||||
|
state = {}
|
||||||
|
state[not_present] = "Not Present"
|
||||||
|
state[ok] = "OK"
|
||||||
|
state[warning] = "Warning"
|
||||||
|
state[critical] = "Critical"
|
||||||
|
state[unknown] = "Unknown"
|
||||||
|
|
||||||
|
|
||||||
|
longserviceoutput = "\n"
|
||||||
|
perfdata = ""
|
||||||
|
summary = ""
|
||||||
|
sudo = False
|
||||||
|
|
||||||
|
|
||||||
|
from sys import exit
|
||||||
|
from sys import argv
|
||||||
|
from os import getenv, putenv, environ
|
||||||
|
import subprocess
|
||||||
|
|
||||||
|
|
||||||
|
def print_help():
|
||||||
|
print "check_hpssacli version %s" % version
|
||||||
|
print "This plugin checks HP Array with the hpssacli command"
|
||||||
|
print ""
|
||||||
|
print "Usage: %s " % argv[0]
|
||||||
|
print "Usage: %s [--help]" % argv[0]
|
||||||
|
print "Usage: %s [--version]" % argv[0]
|
||||||
|
print "Usage: %s [--path </path/to/hpssacli>]" % argv[0]
|
||||||
|
print "Usage: %s [--no-perfdata]" % argv[0]
|
||||||
|
print "Usage: %s [--no-longoutput]" % argv[0]
|
||||||
|
print ""
|
||||||
|
|
||||||
|
|
||||||
|
def error(errortext):
|
||||||
|
print "* Error: %s" % errortext
|
||||||
|
print_help()
|
||||||
|
print "* Error: %s" % errortext
|
||||||
|
exit(unknown)
|
||||||
|
|
||||||
|
|
||||||
|
def debug(debugtext):
|
||||||
|
global debugging
|
||||||
|
if debugging:
|
||||||
|
print debugtext
|
||||||
|
|
||||||
|
|
||||||
|
def runCommand(command):
|
||||||
|
""" Run command from the shell prompt. Exit Nagios style if unsuccessful"""
|
||||||
|
proc = subprocess.Popen(command,
|
||||||
|
shell=True,
|
||||||
|
stdout=subprocess.PIPE,
|
||||||
|
stderr=subprocess.PIPE,
|
||||||
|
)
|
||||||
|
stdout, stderr = proc.communicate('through stdin to stdout')
|
||||||
|
if proc.returncode > 0:
|
||||||
|
print "Error %s: %s\n command was: '%s'"\
|
||||||
|
% (proc.returncode, stderr.strip(), command)
|
||||||
|
debug("results: %s" % (stdout.strip()))
|
||||||
|
if proc.returncode == 127: # File not found, lets print path
|
||||||
|
path = getenv("PATH")
|
||||||
|
print "Check if your path is correct %s" % (path)
|
||||||
|
if stderr.find('Password:') == 0 and command.find('sudo') == 0:
|
||||||
|
print "Check if user is in the sudoers file"
|
||||||
|
if stderr.find('sorry, you must have a tty to run sudo') == 0 and command.find('sudo') == 0:
|
||||||
|
print "Please remove 'requiretty' from /etc/sudoers"
|
||||||
|
exit(unknown)
|
||||||
|
else:
|
||||||
|
return stdout
|
||||||
|
|
||||||
|
|
||||||
|
def end():
|
||||||
|
global summary
|
||||||
|
global longserviceoutput
|
||||||
|
global perfdata
|
||||||
|
global nagios_status
|
||||||
|
print "%s - %s | %s" % (state[nagios_status], summary, perfdata)
|
||||||
|
print longserviceoutput
|
||||||
|
if nagios_status < 0:
|
||||||
|
nagios_status = unknown
|
||||||
|
exit(nagios_status)
|
||||||
|
|
||||||
|
|
||||||
|
def add_perfdata(text):
|
||||||
|
global perfdata
|
||||||
|
text = text.strip()
|
||||||
|
perfdata = perfdata + " %s " % (text)
|
||||||
|
|
||||||
|
|
||||||
|
def add_long(text):
|
||||||
|
global longserviceoutput
|
||||||
|
longserviceoutput = longserviceoutput + text + '\n'
|
||||||
|
|
||||||
|
|
||||||
|
def add_summary(text):
|
||||||
|
global summary
|
||||||
|
summary = summary + text
|
||||||
|
|
||||||
|
|
||||||
|
def set_path(path):
|
||||||
|
current_path = getenv('PATH')
|
||||||
|
if current_path.find('C:\\') > -1: # We are on this platform
|
||||||
|
if path == '':
|
||||||
|
path = ";C:\Program Files\hp\hpssacli\Bin"
|
||||||
|
path = path + ";C:\Program Files (x86)\hp\hpssacli\Bin"
|
||||||
|
path = path + ";C:\Program Files\Smart Storage Administrator\ssacli\bin"
|
||||||
|
else:
|
||||||
|
path = ';' + path
|
||||||
|
else: # Unix/Linux, etc
|
||||||
|
if path == '':
|
||||||
|
path = ":/usr/sbin"
|
||||||
|
else:
|
||||||
|
path = ':' + path
|
||||||
|
current_path = "%s%s" % (current_path, path)
|
||||||
|
environ['PATH'] = current_path
|
||||||
|
|
||||||
|
|
||||||
|
def run_hpssacli(run_type='controllers', controller=None):
|
||||||
|
if run_type == 'controllers':
|
||||||
|
command = "hpssacli controller all show detail"
|
||||||
|
elif run_type in ('logicaldisks', 'physicaldisks'):
|
||||||
|
if 'Slot' not in controller:
|
||||||
|
add_summary("Controller not found")
|
||||||
|
end()
|
||||||
|
identifier = 'slot=%s' % (controller['Slot'])
|
||||||
|
command = "hpssacli controller %s %s all show detail"
|
||||||
|
if run_type == 'logicaldisks':
|
||||||
|
subcommand = 'ld'
|
||||||
|
elif run_type == 'physicaldisks':
|
||||||
|
subcommand = 'pd'
|
||||||
|
else:
|
||||||
|
end()
|
||||||
|
return
|
||||||
|
command = command % (identifier, subcommand)
|
||||||
|
debug(command)
|
||||||
|
if sudo:
|
||||||
|
command = "sudo " + command
|
||||||
|
output = runCommand(command)
|
||||||
|
# Some basic error checking
|
||||||
|
error_strings = ['Permission denied']
|
||||||
|
error_strings.append('Error: You need to have administrator rights to continue.')
|
||||||
|
for error in error_strings:
|
||||||
|
if output.find(error) > -1 and output.find("sudo") != 0:
|
||||||
|
command = "sudo " + command
|
||||||
|
print command
|
||||||
|
output = runCommand(command)
|
||||||
|
output = output.split('\n')
|
||||||
|
objects = []
|
||||||
|
my_object = None
|
||||||
|
for i in output:
|
||||||
|
if len(i) == 0:
|
||||||
|
continue
|
||||||
|
if i.strip() == '':
|
||||||
|
continue
|
||||||
|
if i.startswith('Note:'):
|
||||||
|
continue
|
||||||
|
if run_type == 'controllers' and i[0] != ' ': # space on first line
|
||||||
|
if my_object and not my_object in objects:
|
||||||
|
objects.append(my_object)
|
||||||
|
my_object = {}
|
||||||
|
my_object['name'] = i
|
||||||
|
elif run_type == 'logicaldisks' and i.find('Logical Drive:') > 0:
|
||||||
|
if my_object and not my_object in objects:
|
||||||
|
objects.append(my_object)
|
||||||
|
my_object = {}
|
||||||
|
my_object['name'] = i.strip()
|
||||||
|
elif run_type == 'physicaldisks' and i.find('physicaldrive') > 0:
|
||||||
|
if my_object and not my_object in objects:
|
||||||
|
objects.append(my_object)
|
||||||
|
my_object = {}
|
||||||
|
my_object['name'] = i.strip()
|
||||||
|
else:
|
||||||
|
i = i.strip()
|
||||||
|
if i.find(':') < 1:
|
||||||
|
continue
|
||||||
|
i = i.split(':')
|
||||||
|
if i[0] == '':
|
||||||
|
continue # skip empty lines
|
||||||
|
if len(i) == 1:
|
||||||
|
continue
|
||||||
|
key = i[0].strip()
|
||||||
|
value = ' '.join(i[1:]).strip()
|
||||||
|
my_object[key] = value
|
||||||
|
if my_object and not my_object in objects:
|
||||||
|
objects.append(my_object)
|
||||||
|
return objects
|
||||||
|
|
||||||
|
|
||||||
|
controllers = []
|
||||||
|
|
||||||
|
|
||||||
|
def check_controllers():
|
||||||
|
global controllers
|
||||||
|
status = -1
|
||||||
|
controllers = run_hpssacli()
|
||||||
|
if len(controllers) == 0:
|
||||||
|
add_summary("No Disk Controllers Found. Exiting...")
|
||||||
|
global nagios_state
|
||||||
|
nagios_state = unknown
|
||||||
|
end()
|
||||||
|
add_summary("Found %s controllers" % (len(controllers)))
|
||||||
|
for i in controllers:
|
||||||
|
controller_status = check(i, 'Controller Status', 'OK')
|
||||||
|
status = max(status, controller_status)
|
||||||
|
|
||||||
|
cache_status = check(i, 'Cache Status')
|
||||||
|
status = max(status, cache_status)
|
||||||
|
|
||||||
|
controller_serial = 'n/a'
|
||||||
|
cache_serial = 'n/a'
|
||||||
|
if 'Serial Number' in i:
|
||||||
|
controller_serial = i['Serial Number']
|
||||||
|
if 'Cache Serial Number' in i:
|
||||||
|
cache_serial = i['Cache Serial Number']
|
||||||
|
add_long("%s" % (i['name']))
|
||||||
|
add_long("- Controller Status: %s (sn: %s)"
|
||||||
|
% (state[controller_status], controller_serial))
|
||||||
|
add_long("- Cache Status: %s (sn: %s)"
|
||||||
|
% (state[cache_status], cache_serial))
|
||||||
|
|
||||||
|
if controller_status > ok or cache_status > ok:
|
||||||
|
add_summary(";%s on %s;" % (state[controller_status], i['name']))
|
||||||
|
|
||||||
|
add_summary(', ')
|
||||||
|
return status
|
||||||
|
|
||||||
|
|
||||||
|
def check_logicaldisks():
|
||||||
|
global controllers
|
||||||
|
if len(controllers) < 1:
|
||||||
|
controllers = run_hpssacli()
|
||||||
|
logicaldisks = []
|
||||||
|
for controller in controllers:
|
||||||
|
for ld in run_hpssacli(run_type='logicaldisks',
|
||||||
|
controller=controller):
|
||||||
|
logicaldisks.append(ld)
|
||||||
|
status = -1
|
||||||
|
add_long("\nChecking logical Disks:")
|
||||||
|
add_summary("%s logicaldisks" % (len(logicaldisks)))
|
||||||
|
for i in logicaldisks:
|
||||||
|
ld_status = check(i, 'Status')
|
||||||
|
status = max(status, ld_status)
|
||||||
|
|
||||||
|
if i.get('Status') == 'Failed':
|
||||||
|
status = max(status, critical)
|
||||||
|
|
||||||
|
mount_point = i['Mount Points']
|
||||||
|
add_long("- %s (%s) = %s" % (i['name'], mount_point, state[ld_status]))
|
||||||
|
add_summary(". ")
|
||||||
|
|
||||||
|
|
||||||
|
def check_physicaldisks():
|
||||||
|
global controllers
|
||||||
|
disktype = 'physicaldisks'
|
||||||
|
if len(controllers) < 1:
|
||||||
|
controllers = run_hpssacli()
|
||||||
|
disks = []
|
||||||
|
for controller in controllers:
|
||||||
|
for disk in run_hpssacli(run_type=disktype, controller=controller):
|
||||||
|
disks.append(disk)
|
||||||
|
status = -1
|
||||||
|
add_long("\nChecking Physical Disks:")
|
||||||
|
add_summary("%s %s" % (len(disks), disktype))
|
||||||
|
for i in disks:
|
||||||
|
disk_status = check(i, 'Status')
|
||||||
|
status = max(status, disk_status)
|
||||||
|
|
||||||
|
size = i['Size']
|
||||||
|
firmware = i['Firmware Revision']
|
||||||
|
interface = i['Interface Type']
|
||||||
|
serial = i['Serial Number']
|
||||||
|
model = i['Model']
|
||||||
|
add_long("- %s, %s, %s = %s" %
|
||||||
|
(i['name'], interface, size, state[disk_status])
|
||||||
|
)
|
||||||
|
if disk_status > ok:
|
||||||
|
error_str = "-- Replace drive, firmware=%s, model=%s, serial=%s"
|
||||||
|
add_long(error_str % (firmware, model, serial))
|
||||||
|
if status > ok:
|
||||||
|
add_summary("(errors)")
|
||||||
|
add_summary(". ")
|
||||||
|
|
||||||
|
|
||||||
|
def check(my_object, field, valid_states=None):
|
||||||
|
if valid_states is None:
|
||||||
|
valid_states = ['OK']
|
||||||
|
state = -1
|
||||||
|
global nagios_status
|
||||||
|
if field in my_object:
|
||||||
|
if my_object[field] in valid_states:
|
||||||
|
state = ok
|
||||||
|
else:
|
||||||
|
state = warning
|
||||||
|
nagios_status = max(nagios_status, state)
|
||||||
|
return state
|
||||||
|
|
||||||
|
|
||||||
|
def parse_arguments():
|
||||||
|
arguments = argv[1:]
|
||||||
|
while len(arguments) > 0:
|
||||||
|
arg = arguments.pop(0)
|
||||||
|
if arg == '--help':
|
||||||
|
print_help()
|
||||||
|
exit(ok)
|
||||||
|
elif arg == '--path':
|
||||||
|
path = arguments.pop(0)
|
||||||
|
set_path(path)
|
||||||
|
elif arg == '--debug':
|
||||||
|
global debugging
|
||||||
|
debugging = True
|
||||||
|
elif arg == '--sudo':
|
||||||
|
global sudo
|
||||||
|
sudo = True
|
||||||
|
else:
|
||||||
|
print_help()
|
||||||
|
exit(unknown)
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
parse_arguments()
|
||||||
|
set_path('')
|
||||||
|
check_controllers()
|
||||||
|
check_logicaldisks()
|
||||||
|
check_physicaldisks()
|
||||||
|
end()
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
||||||
45
check_hpssacli/nagios-okplugin-check_hpssacli.spec
Normal file
45
check_hpssacli/nagios-okplugin-check_hpssacli.spec
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
%define debug_package %{nil}
|
||||||
|
|
||||||
|
Summary: A Nagios plugin to check HP Array with hpssacli
|
||||||
|
Name: nagios-okplugin-check_hpssacli
|
||||||
|
Version: 1
|
||||||
|
Release: 1%{?dist}
|
||||||
|
License: GPLv2+
|
||||||
|
Group: Applications/System
|
||||||
|
URL: http://opensource.is/trac/wiki/check_hpssacli
|
||||||
|
Source0: http://opensource.ok.is/trac/browser/nagios-plugins/check_hpssacli/releases/nagios-okplugin-check_hpssacli-%{version}.tar.gz
|
||||||
|
Requires: hpssacli
|
||||||
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
|
Packager: Gardar Thorsteinsson <gardar@ok.is>
|
||||||
|
|
||||||
|
|
||||||
|
%description
|
||||||
|
Checks HP Array with hpssacli
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%setup -q
|
||||||
|
perl -pi -e "s|/usr/lib|%{_libdir}|g" nrpe.d/check_hpssacli.cfg
|
||||||
|
perl -pi -e "s|/usr/lib64|%{_libdir}|g" sudoers.d/*
|
||||||
|
|
||||||
|
%build
|
||||||
|
|
||||||
|
|
||||||
|
%install
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
install -D -p -m 0755 check_hpssacli.py %{buildroot}%{_libdir}/nagios/plugins/check_hpssacli.py
|
||||||
|
install -D -p -m 0755 nrpe.d/check_hpssacli.cfg %{buildroot}/etc/nrpe.d/check_hpssacli.cfg
|
||||||
|
install -D -p -m 0440 sudoers.d/check_hpssacli %{buildroot}/etc/sudoers.d/check_hpssacli
|
||||||
|
|
||||||
|
%clean
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
|
||||||
|
%files
|
||||||
|
%defattr(-,root,root,-)
|
||||||
|
%doc README LICENSE
|
||||||
|
%{_libdir}/nagios/plugins/*
|
||||||
|
/etc/nrpe.d/check_hpssacli.cfg
|
||||||
|
/etc/sudoers.d/check_hpssacli
|
||||||
|
|
||||||
|
%changelog
|
||||||
|
* Fri Jun 14 2019 Gardar Thorsteinsson <gardar@ok.is> 1.1
|
||||||
|
- Initial packaging
|
||||||
2
check_hpssacli/nrpe.d/check_hpssacli.cfg
Normal file
2
check_hpssacli/nrpe.d/check_hpssacli.cfg
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
command[check_hpssacli]=sudo /usr/lib/nagios/plugins/check_hpssacli.py
|
||||||
|
|
||||||
2
check_hpssacli/sudoers.d/check_hpssacli
Normal file
2
check_hpssacli/sudoers.d/check_hpssacli
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
Defaults:nrpe !requiretty
|
||||||
|
nrpe ALL=(ALL) NOPASSWD: /usr/lib64/nagios/plugins/check_hpssacli.py
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -2,8 +2,8 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check IBM Bladecenters
|
Summary: A Nagios plugin to check IBM Bladecenters
|
||||||
Name: nagios-okplugin-check_ibm_bladecenter
|
Name: nagios-okplugin-check_ibm_bladecenter
|
||||||
Version: 1.1.2
|
Version: 4
|
||||||
Release: 3%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
URL: http://opensource.ok.is/trac/wiki/Nagios-OKPlugin-check_ibm_bladecenter
|
URL: http://opensource.ok.is/trac/wiki/Nagios-OKPlugin-check_ibm_bladecenter
|
||||||
@@ -40,6 +40,21 @@ rm -rf %{buildroot}
|
|||||||
#%config(noreplace) %{_sysconfdir}/nrpe.d/check_bond.cfg
|
#%config(noreplace) %{_sysconfdir}/nrpe.d/check_bond.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri Feb 21 2014 Pall Sigurdsson <palli@opensource.is> 4-1
|
||||||
|
-
|
||||||
|
|
||||||
|
* Fri Feb 21 2014 Unknown name 3-1
|
||||||
|
- Merge branch 'master' of github.com:opinkerfi/nagios-plugins
|
||||||
|
(palli@opensource.is)
|
||||||
|
- ibm_bladecenter - another firmware bug workaround (palli@opensource.is)
|
||||||
|
- pep8 fixes (palli@opensource.is)
|
||||||
|
- Fix workaround for firmware bug (palli@opensource.is)
|
||||||
|
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 2-1
|
||||||
|
- Merge branch 'master' of github.com:opinkerfi/misc (palli@opensource.is)
|
||||||
|
- --exclude option added. Added workaround around false positives
|
||||||
|
(palli@opensource.is)
|
||||||
|
|
||||||
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.1.2-3
|
* Thu Aug 23 2012 Pall Sigurdsson <palli@opensource.is> 1.1.2-3
|
||||||
- version number of scripts bumped (palli@opensource.is)
|
- version number of scripts bumped (palli@opensource.is)
|
||||||
|
|
||||||
|
|||||||
@@ -1,3 +0,0 @@
|
|||||||
check_ipa
|
|
||||||
|
|
||||||
Various checks for IPA http://freeipa.org/ server
|
|
||||||
19
check_ipa/README.md
Normal file
19
check_ipa/README.md
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
check_ipa_replication
|
||||||
|
=====================
|
||||||
|
You need some configuration for this plugin to have access to replication
|
||||||
|
information.
|
||||||
|
|
||||||
|
Allow anonymous read to replication information
|
||||||
|
-----------------------------------------------
|
||||||
|
You will need to do this for every IPA server, masters and replicas
|
||||||
|
|
||||||
|
```
|
||||||
|
ldapmodify -x -D "cn=directory manager" -W -f grant_anonymous_replication_view.ldif -h ipa-host.example.com
|
||||||
|
```
|
||||||
|
|
||||||
|
Configure the directory manager credentials
|
||||||
|
-------------------------------------------
|
||||||
|
NOT RECOMENDED, you can use -D and -w with the directory manager credentials
|
||||||
|
and the plugin will work as expected.
|
||||||
|
|
||||||
|
|
||||||
@@ -46,10 +46,13 @@ except Exception, e:
|
|||||||
# Loop through replication agreements
|
# Loop through replication agreements
|
||||||
for rhost in replication:
|
for rhost in replication:
|
||||||
plugin.add_summary("Replica %s Status: %s" % (rhost[1]['nsDS5ReplicaHost'][0], rhost[1]['nsds5replicaLastUpdateStatus'][0]))
|
plugin.add_summary("Replica %s Status: %s" % (rhost[1]['nsDS5ReplicaHost'][0], rhost[1]['nsds5replicaLastUpdateStatus'][0]))
|
||||||
if rhost[1]['nsds5replicaLastUpdateStatus'][0][:2] != "0 ":
|
if rhost[1]['nsds5replicaLastUpdateStatus'][0][7:8] == "0":
|
||||||
plugin.status(critical)
|
|
||||||
else:
|
|
||||||
plugin.status(ok)
|
plugin.status(ok)
|
||||||
|
elif rhost[1]['nsds5replicaLastUpdateStatus'][0][7:8] == "1":
|
||||||
|
# Busy Replica is not an error, its "unknown" (but its "ok" for now)
|
||||||
|
plugin.status(ok)
|
||||||
|
else:
|
||||||
|
plugin.status(critical)
|
||||||
|
|
||||||
if not len(replication):
|
if not len(replication):
|
||||||
plugin.add_summary("Warning: No replicas found")
|
plugin.add_summary("Warning: No replicas found")
|
||||||
|
|||||||
4
check_ipa/grant_anonymous_replication_view.ldif
Normal file
4
check_ipa/grant_anonymous_replication_view.ldif
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
dn: cn="dc=mr,dc=lan",cn=mapping tree,cn=config
|
||||||
|
changetype: modify
|
||||||
|
add: aci
|
||||||
|
aci: (targetattr=*)(targetfilter="(|(objectclass=nsds5replicationagreement)(objectclass=nsDSWindowsReplicationAgreement))")(version 3.0; aci "permission:Read Replication Agreements"; allow (read, search, compare) groupdn = "ldap:///anyone";)
|
||||||
@@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check IPA server status
|
Summary: A Nagios plugin to check IPA server status
|
||||||
Name: nagios-okplugin-%{plugin}
|
Name: nagios-okplugin-%{plugin}
|
||||||
Version: 0.0.3
|
Version: 0.0.4
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -37,10 +37,17 @@ rm -rf %{buildroot}
|
|||||||
%files
|
%files
|
||||||
%defattr(-,root,root,-)
|
%defattr(-,root,root,-)
|
||||||
%doc README
|
%doc README
|
||||||
|
%doc grant_anonymous_replication_view.ldif
|
||||||
%{_libdir}/nagios/plugins/*
|
%{_libdir}/nagios/plugins/*
|
||||||
%config(noreplace) %{_sysconfdir}/nrpe.d/check_ipa.cfg
|
%config(noreplace) %{_sysconfdir}/nrpe.d/check_ipa.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri Apr 04 2014 Tomas Edwardsson <tommi@tommi.org> 0.0.4-1
|
||||||
|
- Renamed to markdown (tommi@tommi.org)
|
||||||
|
- Added examples and documentation (tommi@tommi.org)
|
||||||
|
- Missing colon (tommi@tommi.org)
|
||||||
|
- Added missing OK when things worked out (tommi@tommi.org)
|
||||||
|
|
||||||
* Thu Apr 25 2013 Tomas Edwardsson <tommi@tommi.org> 0.0.3-1
|
* Thu Apr 25 2013 Tomas Edwardsson <tommi@tommi.org> 0.0.3-1
|
||||||
- Preliminary testing done, released
|
- Preliminary testing done, released
|
||||||
- Various errors in syntax fixed (tommi@tommi.org)
|
- Various errors in syntax fixed (tommi@tommi.org)
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check Cisco Ironport
|
Summary: A Nagios plugin to check Cisco Ironport
|
||||||
Name: nagios-okplugin-check_ironport
|
Name: nagios-okplugin-check_ironport
|
||||||
Version: 1.1.4
|
Version: 2
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -37,6 +37,10 @@ rm -rf %{buildroot}
|
|||||||
#%config(noreplace) %{_sysconfdir}/nrpe.d/check_bond.cfg
|
#%config(noreplace) %{_sysconfdir}/nrpe.d/check_bond.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 2-1
|
||||||
|
- Merge branch 'master' of https://opensource.ok.is/git/misc
|
||||||
|
(palli@opensource.is)
|
||||||
|
|
||||||
* Tue Jul 31 2012 Pall Sigurdsson <palli@opensource.is> 1.1.4-1
|
* Tue Jul 31 2012 Pall Sigurdsson <palli@opensource.is> 1.1.4-1
|
||||||
- initial packaging for nagios-okplugin-check_ironport (palli@opensource.is)
|
- initial packaging for nagios-okplugin-check_ironport (palli@opensource.is)
|
||||||
|
|
||||||
|
|||||||
117
check_lvm_mirror/check_lvm_mirror.py
Normal file
117
check_lvm_mirror/check_lvm_mirror.py
Normal file
@@ -0,0 +1,117 @@
|
|||||||
|
#!/usr/bin/python
|
||||||
|
|
||||||
|
from pynag.Plugins import simple as Plugin, WARNING, CRITICAL, UNKNOWN, OK
|
||||||
|
from subprocess import Popen, PIPE
|
||||||
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
global plugin
|
||||||
|
|
||||||
|
plugin = Plugin(must_threshold=False)
|
||||||
|
plugin.add_arg("l", "logical-volume",
|
||||||
|
"Comma seperated list of VG/LV, eg vg00/data,vg00/snap",
|
||||||
|
required=False)
|
||||||
|
plugin.add_arg("V", "volume-group",
|
||||||
|
"Comma seperated list of VG, eg vg00,vg01",
|
||||||
|
required=False)
|
||||||
|
plugin.add_arg("a", "check-all", "Check all LVs", required=False,
|
||||||
|
action="store_true")
|
||||||
|
plugin.activate()
|
||||||
|
|
||||||
|
lvs = plugin["logical-volume"] and plugin["logical-volume"].split(
|
||||||
|
",") or []
|
||||||
|
vgs = plugin["volume-group"] and plugin["volume-group"].split(",") or []
|
||||||
|
|
||||||
|
if not lvs and not vgs and not plugin['check-all']:
|
||||||
|
plugin.parser.error(
|
||||||
|
"Either logical-volume or volume-group must be specified")
|
||||||
|
elif plugin['check-all'] and ( lvs or vgs ):
|
||||||
|
plugin.parser.error(
|
||||||
|
"Mixing check-all and logical-volume or volume-group does not make sense")
|
||||||
|
|
||||||
|
check_mirror(lvs, vgs, plugin['check-all'], plugin['host'])
|
||||||
|
|
||||||
|
(code, message) = (plugin.check_messages(joinallstr="\n"))
|
||||||
|
plugin.nagios_exit(code, message)
|
||||||
|
|
||||||
|
|
||||||
|
def check_mirror(lv_list, vg_list, check_all, hostname):
|
||||||
|
# Ensure the right locale for text parsing
|
||||||
|
"""
|
||||||
|
|
||||||
|
:rtype : None
|
||||||
|
"""
|
||||||
|
# Change lang setting for string consitency
|
||||||
|
env = os.environ.copy()
|
||||||
|
env['LC_ALL'] = 'C'
|
||||||
|
|
||||||
|
# Remote execution
|
||||||
|
if hostname:
|
||||||
|
cmd = ['check_nrpe', '-H', hostname, '-c', 'get_lvm_mirrors']
|
||||||
|
# Local
|
||||||
|
else:
|
||||||
|
cmd = ["lvs", "--separator", ";", "-o",
|
||||||
|
"vg_name,lv_name,lv_attr,copy_percent"]
|
||||||
|
# Execute lvs
|
||||||
|
ret = None
|
||||||
|
lvs_output = None
|
||||||
|
try:
|
||||||
|
lvs = Popen(cmd, stdout=PIPE, shell=False, env=env)
|
||||||
|
ret = lvs.wait()
|
||||||
|
lvs_output = lvs.stdout.readlines()
|
||||||
|
except Exception, e:
|
||||||
|
plugin.nagios_exit(UNKNOWN, "Unable to execute lvs: %s" % (e))
|
||||||
|
|
||||||
|
if ret != 0:
|
||||||
|
plugin.nagios_exit(CRITICAL,
|
||||||
|
"lvs execution failed, return code %i" % (ret))
|
||||||
|
all_lvs = []
|
||||||
|
all_vgs = []
|
||||||
|
|
||||||
|
# Loop through lvs output
|
||||||
|
linenumber = 0
|
||||||
|
for l in lvs_output:
|
||||||
|
linenumber += 1
|
||||||
|
try:
|
||||||
|
vg_name, lv_name, lv_attr, copy_percent = l.strip().split(";")
|
||||||
|
except ValueError as error:
|
||||||
|
plugin.add_message(UNKNOWN,
|
||||||
|
"Unable to parse lvs line %i: %s\n%s" % (
|
||||||
|
linenumber, error, l))
|
||||||
|
continue
|
||||||
|
all_lvs.append("%s/%s" % (vg_name, lv_name))
|
||||||
|
if vg_name not in all_vgs:
|
||||||
|
all_vgs.append(vg_name)
|
||||||
|
|
||||||
|
if check_all or "%s/%s" % (
|
||||||
|
vg_name, lv_name) in lv_list or vg_name in vg_list:
|
||||||
|
if lv_attr[0] != "m" and lv_attr[0] != "M":
|
||||||
|
plugin.add_message(CRITICAL,
|
||||||
|
"LV %s/%s not mirrored" % (vg_name, lv_name))
|
||||||
|
elif lv_attr[2] != "a":
|
||||||
|
plugin.add_message(CRITICAL,
|
||||||
|
"LV %s/%s not active" % (vg_name, lv_name))
|
||||||
|
elif lv_attr[5] != "o":
|
||||||
|
plugin.add_message(CRITICAL,
|
||||||
|
"LV %s/%s not open" % (vg_name, lv_name))
|
||||||
|
elif float(copy_percent or 0) < 100:
|
||||||
|
plugin.add_message(WARNING, "LV %s/%s Copy Percent %s" % (
|
||||||
|
vg_name, lv_name, copy_percent))
|
||||||
|
else:
|
||||||
|
plugin.add_message(OK, "LV %s/%s functioning" % (vg_name, lv_name))
|
||||||
|
|
||||||
|
# Find lvs that were specified in cmd line but were not found via lvs
|
||||||
|
for v in vg_list:
|
||||||
|
if v not in all_vgs:
|
||||||
|
plugin.add_message(CRITICAL, "VG %s not found" % (v))
|
||||||
|
|
||||||
|
# Find lvs that were specified in cmd line but were not found via lvs
|
||||||
|
for l in lv_list:
|
||||||
|
if l not in all_lvs:
|
||||||
|
plugin.add_message(CRITICAL, "LV %s not found" % (l))
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
|
|
||||||
|
|
||||||
1
check_msa_hardware-pl/README.md
Normal file
1
check_msa_hardware-pl/README.md
Normal file
@@ -0,0 +1 @@
|
|||||||
|
Checks hardware status of MSA disk arrays also known as HP P2000
|
||||||
0
check_msa_hardware-pl/check_msa_hardware-pl → check_msa_hardware-pl/check_msa_hardware
Normal file → Executable file
0
check_msa_hardware-pl/check_msa_hardware-pl → check_msa_hardware-pl/check_msa_hardware
Normal file → Executable file
72
check_msa_hardware-pl/nagios-okplugin-check_msa.spec
Normal file
72
check_msa_hardware-pl/nagios-okplugin-check_msa.spec
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
%define debug_package %{nil}
|
||||||
|
%define plugin check_msa_hardware
|
||||||
|
%define packager Gardar Thorsteinsson <gardar@ok.is>
|
||||||
|
|
||||||
|
Summary: A Nagios plugin to check status of an MSA (HP P2000) disk array
|
||||||
|
Name: nagios-okplugin-%{plugin}
|
||||||
|
Version: 1.0.5
|
||||||
|
Release: 2%{?dist}
|
||||||
|
License: GPLv3+
|
||||||
|
Group: Applications/System
|
||||||
|
URL: https://github.com/opinkerfi/nagios-plugins/tree/master/%{plugin}
|
||||||
|
Source0: https://github.com/opinkerfi/nagios-plugins/tree/master/%{plugin}/releases/%{name}-%{version}.tar.gz
|
||||||
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
|
Packager: %{packager}
|
||||||
|
BuildArch: noarch
|
||||||
|
Requires: pynag
|
||||||
|
|
||||||
|
|
||||||
|
%description
|
||||||
|
Checks status of a remote MSA disk array, also known as HP P2000
|
||||||
|
%prep
|
||||||
|
%setup -q
|
||||||
|
|
||||||
|
%global __requires_exclude %{?__requires_exclude:%__requires_exclude}|}^perl\\(utils\\)
|
||||||
|
|
||||||
|
%build
|
||||||
|
|
||||||
|
|
||||||
|
%install
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
install -D -p -m 0755 %{plugin} %{buildroot}%{_libdir}/nagios/plugins/%{plugin}
|
||||||
|
mkdir -p %{buildroot}%{_sysconfdir}/nrpe.d
|
||||||
|
sed "s^/usr/lib64^%{_libdir}^g" nrpe.d/%{plugin}.cfg > %{buildroot}%{_sysconfdir}/nrpe.d/%{plugin}.cfg
|
||||||
|
|
||||||
|
# Temporary fix for selinux
|
||||||
|
chcon system_u:object_r:nagios_unconfined_plugin_exec_t:s0 %{plugin} %{buildroot}%{_libdir}/nagios/plugins/%{plugin}
|
||||||
|
|
||||||
|
%clean
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
|
||||||
|
%post
|
||||||
|
/sbin/service nrpe status &> /dev/null && /sbin/service nrpe reload || :
|
||||||
|
|
||||||
|
%files
|
||||||
|
%defattr(-,root,root,-)
|
||||||
|
%doc README.md
|
||||||
|
%{_libdir}/nagios/plugins/*
|
||||||
|
%config(noreplace) %{_sysconfdir}/nrpe.d/%{plugin}.cfg
|
||||||
|
|
||||||
|
%changelog
|
||||||
|
* Fri May 09 2018 Gardar Thorsteinsson <gardar@ok.is> 1.0.5-2
|
||||||
|
- Filter out perl-utils dep
|
||||||
|
|
||||||
|
* Thu Jan 30 2014 Pall Sigurdsson <palli@opensource.is> 1.0.5-1
|
||||||
|
-
|
||||||
|
|
||||||
|
* Thu Jan 30 2014 Pall Sigurdsson <palli@opensource.is> 1.0.4-1
|
||||||
|
- README.md added (you@example.com)
|
||||||
|
- nrpe.d added to check_msa (you@example.com)
|
||||||
|
- rename check_msa_hardware-pl (you@example.com)
|
||||||
|
|
||||||
|
* Thu Jan 30 2014 Pall Sigurdsson <palli@opensource.is> 1.0.3-1
|
||||||
|
- new package built with tito
|
||||||
|
|
||||||
|
* Thu Jan 30 2014 Pall Sigurdsson <palli@opensource.is> 1.0.2-1
|
||||||
|
- new package built with tito
|
||||||
|
|
||||||
|
* Thu Jan 30 2014 Unknown name 1.0.1-1
|
||||||
|
- new package built with tito
|
||||||
|
|
||||||
|
* Fri Jan 27 2014 Pall Sigurdsson 1.0.0-1
|
||||||
|
- Initial Packaging
|
||||||
1
check_msa_hardware-pl/nrpe.d/check_msa_hardware.cfg
Normal file
1
check_msa_hardware-pl/nrpe.d/check_msa_hardware.cfg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
command[check_msa_hardware]=/usr/lib64/nagios/plugins/check_msa_hardware
|
||||||
@@ -48,9 +48,9 @@ print_help() {
|
|||||||
|
|
||||||
echo "Add this to your sudoers file by running visudo to add access:"
|
echo "Add this to your sudoers file by running visudo to add access:"
|
||||||
if [ -r /proc/modules ]; then
|
if [ -r /proc/modules ]; then
|
||||||
echo "Cmnd_Alias MULTIPATH=$MULTIPATH -l"
|
echo "Cmnd_Alias MULTIPATH=$MULTIPATH -ll"
|
||||||
else
|
else
|
||||||
echo "Cmnd_Alias MULTIPATH=$MULTIPATH -l, $SUDO"
|
echo "Cmnd_Alias MULTIPATH=$MULTIPATH -ll, $SUDO"
|
||||||
fi
|
fi
|
||||||
echo "nagios ALL= NOPASSWD: MULTIPATH"
|
echo "nagios ALL= NOPASSWD: MULTIPATH"
|
||||||
echo "The user nagios may very well be nobody or someone else depending on your configuration"
|
echo "The user nagios may very well be nobody or someone else depending on your configuration"
|
||||||
@@ -98,7 +98,7 @@ if [ $(id -un) != "root" ]; then
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
OUTPUT=$($MULTIPATH -l 2>/dev/null)
|
OUTPUT=$($MULTIPATH -ll 2>/dev/null)
|
||||||
if [ $? != 0 ]; then
|
if [ $? != 0 ]; then
|
||||||
# Failed. grab more info why
|
# Failed. grab more info why
|
||||||
if [ $(id -un) != "root" ] && [ `$SUDO -l | grep -c multipath` -eq 0 ]; then
|
if [ $(id -un) != "root" ] && [ `$SUDO -l | grep -c multipath` -eq 0 ]; then
|
||||||
@@ -112,7 +112,7 @@ if [ $? != 0 ]; then
|
|||||||
exit $STATE_UNKNOWN
|
exit $STATE_UNKNOWN
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "MULTIPATH: $(MULTIPATH -l 2>&1)"
|
echo "MULTIPATH: $($MULTIPATH -ll 2>&1)"
|
||||||
exit $STATE_UNKNOWN
|
exit $STATE_UNKNOWN
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -137,6 +137,7 @@ if [ "$NUMPATHS" ]; then
|
|||||||
/^ \\/ {targets++; next} # count targets (lenny)
|
/^ \\/ {targets++; next} # count targets (lenny)
|
||||||
/[0-9]+:[0-9]+:[0-9]+:[0-9]+/ {
|
/[0-9]+:[0-9]+:[0-9]+:[0-9]+/ {
|
||||||
if (/active undef running/) { targets++ } # count targets (squeeze)
|
if (/active undef running/) { targets++ } # count targets (squeeze)
|
||||||
|
if (/active ready running/) { targets++ } # count targets (RHEL6)
|
||||||
next
|
next
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
|
|||||||
14
check_other/README
Normal file
14
check_other/README
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
check_other
|
||||||
|
===========
|
||||||
|
|
||||||
|
This plugin is designed to execute another plugin that is given as an argument.
|
||||||
|
|
||||||
|
Usually you want this to use the perfdata parsing of pynag and you want to alert on specific thresholds in the other plugin.
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
```
|
||||||
|
check_other -- check_nrpe -H localhost -c check_load
|
||||||
|
|
||||||
|
# Same as above, but alert on performance metric load1
|
||||||
|
check_other --threshold metric=load1,warn=2..inf -- check_nrpe -H localhost -c check_load
|
||||||
|
```
|
||||||
50
check_other/check_other
Normal file
50
check_other/check_other
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
# This script runs whatever command is printed on the command line
|
||||||
|
# Usage:
|
||||||
|
# ./check_other -- someotherplugin --arguments-for-the-other-plugin
|
||||||
|
#
|
||||||
|
# Example:
|
||||||
|
# ./check_other -- check_nrpe -H localhost
|
||||||
|
#
|
||||||
|
# If you want to provide options to check_other (for example to enforce a threshold:
|
||||||
|
# ./check_other --threshold=load1,warn=5..inf -- check_nrpe -H localhost check_load
|
||||||
|
|
||||||
|
|
||||||
|
import subprocess
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from pynag.Plugins import PluginHelper
|
||||||
|
from pynag.Utils import runCommand, PluginOutput, PerfData
|
||||||
|
|
||||||
|
p = PluginHelper()
|
||||||
|
|
||||||
|
p.parser.add_option('--string', dest='string', help='run this command (will be shell expanded, use quotes)')
|
||||||
|
p.parse_arguments()
|
||||||
|
|
||||||
|
|
||||||
|
# --string was provided
|
||||||
|
if p.options.string:
|
||||||
|
return_code, stdout, stderr = runCommand(p.options.string)
|
||||||
|
# No --string, and no arguments on the command line
|
||||||
|
elif not p.arguments:
|
||||||
|
p.parser.error("You need to provide an external command as an argument. Try: %s ls" % sys.argv[0])
|
||||||
|
# some arguments were provided
|
||||||
|
else:
|
||||||
|
try:
|
||||||
|
proc = subprocess.Popen(p.arguments, shell=False, stdout=subprocess.PIPE, stderr=subprocess.PIPE,)
|
||||||
|
stdout, stderr = proc.communicate('through stdin to stdout')
|
||||||
|
return_code = proc.returncode
|
||||||
|
except Exception, e:
|
||||||
|
p.set_summary("Failed to execute '%s': %s " % (p.arguments[0], e))
|
||||||
|
p.status(3)
|
||||||
|
p.exit()
|
||||||
|
|
||||||
|
p.status(return_code)
|
||||||
|
other = PluginOutput(stdout)
|
||||||
|
|
||||||
|
p.set_summary(other.summary)
|
||||||
|
p.set_long_output(other.long_output)
|
||||||
|
p._perfdata = PerfData(other.perfdata)
|
||||||
|
|
||||||
|
p.check_all_metrics()
|
||||||
|
p.exit()
|
||||||
@@ -4,10 +4,6 @@ About
|
|||||||
This Nagios plugin checks for available updates using PackageKit
|
This Nagios plugin checks for available updates using PackageKit
|
||||||
http://packagekit.org/ on Linux systems
|
http://packagekit.org/ on Linux systems
|
||||||
|
|
||||||
Draft
|
|
||||||
=====
|
|
||||||
The implementation isn't finished yet.
|
|
||||||
|
|
||||||
Why a new plugin?
|
Why a new plugin?
|
||||||
=================
|
=================
|
||||||
|
|
||||||
|
|||||||
@@ -17,7 +17,7 @@
|
|||||||
|
|
||||||
from subprocess import Popen, PIPE
|
from subprocess import Popen, PIPE
|
||||||
from pynag.Plugins import PluginHelper, unknown, ok
|
from pynag.Plugins import PluginHelper, unknown, ok
|
||||||
|
from collections import defaultdict
|
||||||
known_types = ['Enhancement', 'Normal', 'Bug fix', 'Security']
|
known_types = ['Enhancement', 'Normal', 'Bug fix', 'Security']
|
||||||
|
|
||||||
|
|
||||||
@@ -45,6 +45,11 @@ def main():
|
|||||||
for pkg in pkg_updates[update_type]:
|
for pkg in pkg_updates[update_type]:
|
||||||
p.add_long_output(" %s" % pkg)
|
p.add_long_output(" %s" % pkg)
|
||||||
|
|
||||||
|
for m in known_types:
|
||||||
|
m = m.lower()
|
||||||
|
if not p.get_metric(m):
|
||||||
|
p.add_metric(m, 0)
|
||||||
|
|
||||||
p.check_all_metrics()
|
p.check_all_metrics()
|
||||||
p.exit()
|
p.exit()
|
||||||
|
|
||||||
@@ -57,7 +62,9 @@ def pkcon_get_updates():
|
|||||||
|
|
||||||
:return: { "Bug fix": [ "pkg-1.0.1", "anthr-pkg-3.1.4" ], "Security": [ "pkg2-2.1.1" ],
|
:return: { "Bug fix": [ "pkg-1.0.1", "anthr-pkg-3.1.4" ], "Security": [ "pkg2-2.1.1" ],
|
||||||
"""
|
"""
|
||||||
update_types = {}
|
update_types = defaultdict(list)
|
||||||
|
for t in known_types:
|
||||||
|
update_types[t] = []
|
||||||
|
|
||||||
stdout = ""
|
stdout = ""
|
||||||
stderr = ""
|
stderr = ""
|
||||||
@@ -72,17 +79,17 @@ def pkcon_get_updates():
|
|||||||
|
|
||||||
total_updates = 0
|
total_updates = 0
|
||||||
results_section = False
|
results_section = False
|
||||||
for line in stdout.split("\n"):
|
for line in stdout.splitlines():
|
||||||
if not line:
|
if not line:
|
||||||
continue
|
continue
|
||||||
|
if line.startswith("There are no updates"):
|
||||||
|
continue
|
||||||
if results_section is False and line == "Results:":
|
if results_section is False and line == "Results:":
|
||||||
results_section = True
|
results_section = True
|
||||||
elif results_section:
|
elif results_section:
|
||||||
update_type = line[:13].strip()
|
update_type = line[:13].strip()
|
||||||
update_package = line[13:].strip()
|
update_package = line[13:].strip()
|
||||||
|
|
||||||
if update_type not in update_types:
|
|
||||||
update_types[update_type] = []
|
|
||||||
update_types[update_type].append(update_package)
|
update_types[update_type].append(update_package)
|
||||||
total_updates += 1
|
total_updates += 1
|
||||||
|
|
||||||
@@ -92,9 +99,6 @@ def pkcon_get_updates():
|
|||||||
if results_section is False:
|
if results_section is False:
|
||||||
raise Exception("pkcon returned no 'Results:' section. Output of pkcon command:\n" + stdout)
|
raise Exception("pkcon returned no 'Results:' section. Output of pkcon command:\n" + stdout)
|
||||||
|
|
||||||
for t in known_types:
|
|
||||||
if t not in update_types:
|
|
||||||
update_types[t] = []
|
|
||||||
return total_updates, update_types
|
return total_updates, update_types
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check operating system updates
|
Summary: A Nagios plugin to check operating system updates
|
||||||
Name: nagios-okplugin-%{plugin}
|
Name: nagios-okplugin-%{plugin}
|
||||||
Version: 0.0.5
|
Version: 0.0.7
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv3+
|
License: GPLv3+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -15,7 +15,6 @@ BuildArch: noarch
|
|||||||
Requires: nrpe
|
Requires: nrpe
|
||||||
Requires: pynag
|
Requires: pynag
|
||||||
Requires: PackageKit
|
Requires: PackageKit
|
||||||
Obsoletes: nagios-okplugin-check_yum
|
|
||||||
|
|
||||||
|
|
||||||
%description
|
%description
|
||||||
@@ -32,10 +31,15 @@ rm -rf %{buildroot}
|
|||||||
install -D -p -m 0755 %{plugin} %{buildroot}%{_libdir}/nagios/plugins/%{plugin}
|
install -D -p -m 0755 %{plugin} %{buildroot}%{_libdir}/nagios/plugins/%{plugin}
|
||||||
mkdir -p %{buildroot}%{_sysconfdir}/nrpe.d
|
mkdir -p %{buildroot}%{_sysconfdir}/nrpe.d
|
||||||
sed "s^/usr/lib64^%{_libdir}^g" nrpe.d/%{plugin}.cfg > %{buildroot}%{_sysconfdir}/nrpe.d/%{plugin}.cfg
|
sed "s^/usr/lib64^%{_libdir}^g" nrpe.d/%{plugin}.cfg > %{buildroot}%{_sysconfdir}/nrpe.d/%{plugin}.cfg
|
||||||
|
# Temporary fix for selinux
|
||||||
|
chcon system_u:object_r:nagios_unconfined_plugin_exec_t:s0 %{plugin} %{buildroot}%{_libdir}/nagios/plugins/%{plugin}
|
||||||
|
|
||||||
%clean
|
%clean
|
||||||
rm -rf %{buildroot}
|
rm -rf %{buildroot}
|
||||||
|
|
||||||
|
%post
|
||||||
|
/sbin/service nrpe status &> /dev/null && /sbin/service nrpe reload || :
|
||||||
|
|
||||||
%files
|
%files
|
||||||
%defattr(-,root,root,-)
|
%defattr(-,root,root,-)
|
||||||
%doc README.md
|
%doc README.md
|
||||||
@@ -43,6 +47,18 @@ rm -rf %{buildroot}
|
|||||||
%config(noreplace) %{_sysconfdir}/nrpe.d/%{plugin}.cfg
|
%config(noreplace) %{_sysconfdir}/nrpe.d/%{plugin}.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri Sep 13 2013 Tomas Edwardsson <tommi@tommi.org> 0.0.7-1
|
||||||
|
- check_package_updates - minor refactor (palli@opensource.is)
|
||||||
|
- check_package_updates - fix inconsistent tab/space (palli@opensource.is)
|
||||||
|
- Removed obsoletes and thresholds (tommi@tommi.org)
|
||||||
|
- Removed Draft, should be working pretty good (tommi@tommi.org)
|
||||||
|
- Added --legacy to default since that is the default format (tommi@tommi.org)
|
||||||
|
- Added nrpe reload since moving from check_yum needs it (tommi@tommi.org)
|
||||||
|
- Added obsolete for okplugin check_updates (tommi@tommi.org)
|
||||||
|
|
||||||
|
* Tue Jul 16 2013 Tomas Edwardsson <tommi@tommi.org> 0.0.6-1
|
||||||
|
- Fix failure on a fully patched system (tommi@tommi.org)
|
||||||
|
|
||||||
* Tue Jul 16 2013 Tomas Edwardsson <tommi@tommi.org> 0.0.5-1
|
* Tue Jul 16 2013 Tomas Edwardsson <tommi@tommi.org> 0.0.5-1
|
||||||
- Known types always have a metric, even if 0 (tommi@tommi.org)
|
- Known types always have a metric, even if 0 (tommi@tommi.org)
|
||||||
|
|
||||||
|
|||||||
@@ -1,2 +1,5 @@
|
|||||||
# Critical on security updates, warning if 40 or more total updates
|
# Critical on security updates, warning if 40 or more total updates
|
||||||
command[check_updates]=/usr/lib64/nagios/plugins/check_package_updates --th "metric=security,critical=1..inf" --th "metric=total,warning=40..inf"
|
command[check_package_updates]=/usr/lib64/nagios/plugins/check_package_updates --legacy
|
||||||
|
|
||||||
|
# Critical on security updates
|
||||||
|
command[check_package_updates_security]=/usr/lib64/nagios/plugins/check_package_updates --th "metric=security,critical=1..inf" --legacy
|
||||||
|
|||||||
@@ -72,12 +72,11 @@ def getLocalNodeState(dom):
|
|||||||
"""
|
"""
|
||||||
Get the state of the local node
|
Get the state of the local node
|
||||||
"""
|
"""
|
||||||
hostname = socket.gethostname()
|
|
||||||
nodesList = dom.getElementsByTagName('node')
|
nodesList = dom.getElementsByTagName('node')
|
||||||
nodeState = {}
|
nodeState = {}
|
||||||
|
|
||||||
for node in nodesList:
|
for node in nodesList:
|
||||||
if node.attributes['name'].value == hostname:
|
if node.attributes['local'].value == "1":
|
||||||
nodeState['name'] = node.attributes['name'].value
|
nodeState['name'] = node.attributes['name'].value
|
||||||
nodeState['state'] = node.attributes['state'].value
|
nodeState['state'] = node.attributes['state'].value
|
||||||
nodeState['rgmanager'] = node.attributes['rgmanager'].value
|
nodeState['rgmanager'] = node.attributes['rgmanager'].value
|
||||||
@@ -95,7 +94,6 @@ def getServiceState(dom, service):
|
|||||||
Get the state of the named service
|
Get the state of the named service
|
||||||
"""
|
"""
|
||||||
groupList = dom.getElementsByTagName('group')
|
groupList = dom.getElementsByTagName('group')
|
||||||
hostname = socket.gethostname()
|
|
||||||
serviceState = {}
|
serviceState = {}
|
||||||
for group in groupList:
|
for group in groupList:
|
||||||
if group.attributes['name'].value in (service,"service:"+service,"vm:"+service):
|
if group.attributes['name'].value in (service,"service:"+service,"vm:"+service):
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check Red Hat Cluster suite (rhel5 and rhel6)
|
Summary: A Nagios plugin to check Red Hat Cluster suite (rhel5 and rhel6)
|
||||||
Name: nagios-okplugin-%{plugin_name}
|
Name: nagios-okplugin-%{plugin_name}
|
||||||
Version: %{version}
|
Version: 1
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -45,6 +45,11 @@ rm -rf %{buildroot}
|
|||||||
/etc/nrpe.d/%{plugin_name}.cfg
|
/etc/nrpe.d/%{plugin_name}.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 1-1
|
||||||
|
- Updated rhcs nrpe config as well (tommi@tommi.org)
|
||||||
|
- Added check for suspended services -Z (tommi@tommi.org)
|
||||||
|
- Fix broken libdir on 64-bit platforms (palli@opensource.is)
|
||||||
|
|
||||||
* Thu May 24 2012 Pall Sigurdsson <palli@opensource.is> 0.0.4-1
|
* Thu May 24 2012 Pall Sigurdsson <palli@opensource.is> 0.0.4-1
|
||||||
- version bump of check_rhcs (palli@opensource.is)
|
- version bump of check_rhcs (palli@opensource.is)
|
||||||
- check_rhcs_fence added for rhel6 compatibility (palli@opensource.is)
|
- check_rhcs_fence added for rhel6 compatibility (palli@opensource.is)
|
||||||
|
|||||||
@@ -74,17 +74,17 @@ OUTPUT=`$CHECK_COMMAND`
|
|||||||
RESULT=$?
|
RESULT=$?
|
||||||
|
|
||||||
if [ $RESULT -gt 0 ]; then
|
if [ $RESULT -gt 0 ]; then
|
||||||
echo "Error - Could not run command $CHECK_COMMAND"
|
echo "UNKNOWN - Could not run command $CHECK_COMMAND"
|
||||||
echo "Error was: $OUTPUT"
|
echo "Error was: $OUTPUT"
|
||||||
exit 3
|
exit 3
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Parse the output from the command
|
# Parse the output from the command
|
||||||
if [ "$OUTPUT" == "$STATUS" ]; then
|
if [ "$OUTPUT" == "$STATUS" ]; then
|
||||||
echo "ok, selinux status is $OUTPUT"
|
echo "OK - SELinux status is $OUTPUT"
|
||||||
exit 0
|
exit 0
|
||||||
else
|
else
|
||||||
echo "warning, selinux status is $OUTPUT (supposed to be $STATUS)"
|
echo "WARNING - SELinux status is $OUTPUT (supposed to be $STATUS)"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check SELinux status on Linux servers
|
Summary: A Nagios plugin to check SELinux status on Linux servers
|
||||||
Name: nagios-plugins-check_selinux
|
Name: nagios-plugins-check_selinux
|
||||||
Version: 1.1
|
Version: 1.3
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv3+
|
License: GPLv3+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -35,6 +35,12 @@ rm -rf %{buildroot}
|
|||||||
|
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 1.3-1
|
||||||
|
-
|
||||||
|
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson
|
||||||
|
-
|
||||||
|
|
||||||
* Wed May 22 2013 Tomas Edwardsson <tommi@tommi.org> 1.1-1
|
* Wed May 22 2013 Tomas Edwardsson <tommi@tommi.org> 1.1-1
|
||||||
- new package built with tito
|
- new package built with tito
|
||||||
|
|
||||||
|
|||||||
@@ -2,15 +2,15 @@
|
|||||||
|
|
||||||
Summary: Various nagios plugins to check cpu,memory,interfaces via SNMP
|
Summary: Various nagios plugins to check cpu,memory,interfaces via SNMP
|
||||||
Name: nagios-okplugin-check_snmp
|
Name: nagios-okplugin-check_snmp
|
||||||
Version: 1.0.1
|
Version: 2
|
||||||
Release: 1%{?dist}
|
Release: 2%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
URL: http://opensource.is/trac/wiki/check_snmp
|
URL: http://opensource.is/trac/wiki/check_snmp
|
||||||
Source0: http://opensource.ok.is/trac/browser/nagios-plugins/check_snmp/releases/nagios-okplugin-check_snmp-%{version}.tar.gz
|
Source0: http://opensource.ok.is/trac/browser/nagios-plugins/check_snmp/releases/nagios-okplugin-check_snmp-%{version}.tar.gz
|
||||||
Requires: perl-Net-SNMP
|
Requires: perl-Net-SNMP
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
Packager: Pall Sigurdsson <palli@opensource.is>
|
Packager: Gardar Thorsteinsson <gardar@ok.is>
|
||||||
|
|
||||||
|
|
||||||
%description
|
%description
|
||||||
@@ -20,6 +20,8 @@ Various nagios plugins to check cpu,memory,interfaces via SNMP
|
|||||||
%setup -q
|
%setup -q
|
||||||
#perl -pi -e "s|/usr/lib|%{_libdir}|g" nrpe.d/check_hpacucli.cfg
|
#perl -pi -e "s|/usr/lib|%{_libdir}|g" nrpe.d/check_hpacucli.cfg
|
||||||
|
|
||||||
|
%global __requires_exclude %{?__requires_exclude:%__requires_exclude}|}^perl\\(utils\\)
|
||||||
|
|
||||||
%build
|
%build
|
||||||
|
|
||||||
|
|
||||||
@@ -45,6 +47,12 @@ rm -rf %{buildroot}
|
|||||||
%{_libdir}/nagios/plugins/*
|
%{_libdir}/nagios/plugins/*
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri May 09 2018 Gardar Thorsteinsson <gardar@ok.is> 2-2
|
||||||
|
- Filter out perl-utils dep
|
||||||
|
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 2-1
|
||||||
|
- make sure nagios does not run us in embedded perl (palli@opensource.is)
|
||||||
|
|
||||||
* Mon Mar 12 2012 Pall Sigurdsson <palli@opensource.is> 1.0.1-1
|
* Mon Mar 12 2012 Pall Sigurdsson <palli@opensource.is> 1.0.1-1
|
||||||
- new package built with tito
|
- new package built with tito
|
||||||
|
|
||||||
|
|||||||
77
check_storwize/README.md
Normal file
77
check_storwize/README.md
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
check_storwize.py
|
||||||
|
=================
|
||||||
|
|
||||||
|
Nagios plugin to check the status of a remote Storwize disk array.
|
||||||
|
|
||||||
|
This plugin is designed to be syntactically compatible with check_storwize.sh from nagios exchange
|
||||||
|
with the following differences:
|
||||||
|
|
||||||
|
- Outputs performance data
|
||||||
|
- GPL License
|
||||||
|
- Written in python
|
||||||
|
- More stable plugin results when disk array is broken
|
||||||
|
|
||||||
|
|
||||||
|
USAGE
|
||||||
|
=============
|
||||||
|
```
|
||||||
|
python check_storwize.py --help
|
||||||
|
Usage: check_storwize.py [options]
|
||||||
|
|
||||||
|
Options:
|
||||||
|
-h, --help show this help message and exit
|
||||||
|
-H HOSTNAME, -M HOSTNAME, --hostname=HOSTNAME
|
||||||
|
Hostname or ip address
|
||||||
|
-U USER, --user=USER Log in as this user to storwize
|
||||||
|
-Q QUERY, --query=QUERY
|
||||||
|
Query to send to storwize (see also -L)
|
||||||
|
-L, --list-queries List of valid queries
|
||||||
|
--test Run this plugin in test mode
|
||||||
|
|
||||||
|
Generic Options:
|
||||||
|
--timeout=50 Exit plugin with unknown status after x seconds
|
||||||
|
--threshold=range Thresholds in standard nagios threshold format
|
||||||
|
--th=range Same as --threshold
|
||||||
|
--extra-opts=@file Read options from an ini file. See
|
||||||
|
http://nagiosplugins.org/extra-opts
|
||||||
|
-d, --debug Print debug info
|
||||||
|
|
||||||
|
Display Options:
|
||||||
|
-v, --verbose Print more verbose info
|
||||||
|
--no-perfdata Dont show any performance data
|
||||||
|
--no-longoutput Hide longoutput from the plugin output (i.e. only
|
||||||
|
display first line of the output)
|
||||||
|
--no-summary Hide summary from plugin output
|
||||||
|
--get-metrics Print all available metrics and exit (can be combined
|
||||||
|
with --verbose)
|
||||||
|
--legacy Deprecated, do not use
|
||||||
|
```
|
||||||
|
|
||||||
|
EXAMPLES
|
||||||
|
========
|
||||||
|
```
|
||||||
|
# List array status
|
||||||
|
python check_storwize -H remote_host -U username -Q lsarray
|
||||||
|
|
||||||
|
# List vdisk status
|
||||||
|
python check_storwize -H remote_host -U username -Q lsarray
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
Valid modes
|
||||||
|
===========
|
||||||
|
The following is a list of valid modes (at the time of this writing). For an up-to-date list consult check_storwize -L
|
||||||
|
|
||||||
|
* lsarray
|
||||||
|
* lsdrive
|
||||||
|
* lsenclosurebattery
|
||||||
|
* lsenclosurecanister
|
||||||
|
* lsenclosurepsu
|
||||||
|
* lsenclosureslot
|
||||||
|
* lsenclosure
|
||||||
|
* lsmdiskgrp
|
||||||
|
* lsmdskgrp
|
||||||
|
* lsmgrp
|
||||||
|
* lsrcrelationship
|
||||||
|
* lsvdisk
|
||||||
205
check_storwize/check_storwize.py
Normal file
205
check_storwize/check_storwize.py
Normal file
@@ -0,0 +1,205 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
from pynag.Plugins import PluginHelper, ok, warning, critical, unknown
|
||||||
|
from pynag.Utils import runCommand
|
||||||
|
from collections import namedtuple
|
||||||
|
|
||||||
|
valid_queries = "lsarray lsdrive lsenclosurebattery lsenclosurecanister lsenclosurepsu lsenclosureslot lsenclosure lsmdiskgrp lsmdskgrp lsmgrp lsrcrelationship lsvdisk"
|
||||||
|
|
||||||
|
p = PluginHelper()
|
||||||
|
p.add_option("-H", "--hostname", '-M', help="Hostname or ip address", dest="hostname")
|
||||||
|
p.add_option("-U", "--user", help="Log in as this user to storwize", dest="user", default="nagios")
|
||||||
|
p.add_option("-Q", "--query", help="Query to send to storwize (see also -L)", dest="query", default="lsarray")
|
||||||
|
p.add_option("-L", "--list-queries", help="List of valid queries", dest="list_queries", action="store_true")
|
||||||
|
p.add_option("--test", help="Run this plugin in test mode", dest="test", action="store_true")
|
||||||
|
|
||||||
|
p.parse_arguments()
|
||||||
|
|
||||||
|
if p.options.list_queries is True:
|
||||||
|
p.parser.error("Valid Queries: %s" % valid_queries)
|
||||||
|
if not p.options.hostname:
|
||||||
|
p.parser.error("Required options -H is missing")
|
||||||
|
if p.options.query not in valid_queries.split():
|
||||||
|
p.parser.error("%s does not look like a valid query. Use -L for a list of valid queries" % p.options.query)
|
||||||
|
|
||||||
|
query = p.options.query
|
||||||
|
|
||||||
|
|
||||||
|
# Connect to remote storwize and run a connect
|
||||||
|
def run_query():
|
||||||
|
""" Connect to a remote storwize box and run query """
|
||||||
|
command = "ssh %s@%s %s -delim ':'" % (p.options.user, p.options.hostname, p.options.query)
|
||||||
|
if p.options.test:
|
||||||
|
command = "cat %s.txt" % (p.options.query)
|
||||||
|
return_code, stdout, stderr = runCommand(command)
|
||||||
|
|
||||||
|
if return_code != 0:
|
||||||
|
p.status(unknown)
|
||||||
|
p.add_summary("Got error %s when trying to log into remote storwize box" % return_code)
|
||||||
|
p.add_long_output("\ncommand:\n===============\n%s" % command)
|
||||||
|
p.add_long_output("\nStandard output:\n==============\n%s" % (stdout))
|
||||||
|
p.add_long_output("\nStandard stderr:\n==============\n%s" % (stderr))
|
||||||
|
p.exit()
|
||||||
|
if stderr:
|
||||||
|
p.status(unknown)
|
||||||
|
p.add_summary("Error when connecting to storwize: %s" % stderr)
|
||||||
|
p.exit()
|
||||||
|
|
||||||
|
# Parse the output of run query and return a list of "rows"
|
||||||
|
lines = stdout.splitlines()
|
||||||
|
top_line = lines.pop(0)
|
||||||
|
headers = top_line.split(':')
|
||||||
|
Row = namedtuple('Row', ' '.join(headers))
|
||||||
|
rows = []
|
||||||
|
for i in lines:
|
||||||
|
i = i.strip()
|
||||||
|
columns = i.split(':')
|
||||||
|
row = Row(*columns)
|
||||||
|
rows.append(row)
|
||||||
|
return rows
|
||||||
|
|
||||||
|
|
||||||
|
def check_lsmdiskgrp():
|
||||||
|
p.add_summary("%s diskgroups found" % (len(rows)))
|
||||||
|
p.add_metric("number of groups", len(rows))
|
||||||
|
for row in rows:
|
||||||
|
if row.status != 'online':
|
||||||
|
p.status(critical)
|
||||||
|
p.add_summary("group %s is %s." % (row.name, row.status))
|
||||||
|
p.add_long_output("%s: used: %s out of %s" % (row.name, row.used_capacity, row.capacity))
|
||||||
|
# Add a performance metric
|
||||||
|
metric_name = "%s_capacity" % row.name
|
||||||
|
p.add_metric(metric_name, value=row.used_capacity, max=row.capacity)
|
||||||
|
|
||||||
|
|
||||||
|
def check_lsdrive():
|
||||||
|
p.add_summary("%s drives found" % (len(rows)))
|
||||||
|
p.add_metric("number of drives", len(rows))
|
||||||
|
for row in rows:
|
||||||
|
if row.status != 'online':
|
||||||
|
p.status(critical)
|
||||||
|
p.add_summary("drive %s is %s" % (row.id, row.status))
|
||||||
|
|
||||||
|
|
||||||
|
def check_lsmgrp():
|
||||||
|
p.add_summary("%s groups found" % (len(rows)))
|
||||||
|
p.add_metric("number of groups", len(rows))
|
||||||
|
for row in rows:
|
||||||
|
if row.status != 'online':
|
||||||
|
p.status(critical)
|
||||||
|
p.add_summary("group %s is %s" % (row.name, row.status))
|
||||||
|
|
||||||
|
|
||||||
|
def check_lsenclosurebattery():
|
||||||
|
p.add_summary("%s batteries found" % (len(rows)))
|
||||||
|
p.add_metric("number of batteries", len(rows))
|
||||||
|
for row in rows:
|
||||||
|
if row.status != 'online':
|
||||||
|
p.status(critical)
|
||||||
|
p.add_summary("battery %s:%s is %s" % (row.enclosure_id, row.battery_id, row.status))
|
||||||
|
|
||||||
|
|
||||||
|
def check_lsenclosurecanister():
|
||||||
|
p.add_summary("%s canisters found" % (len(rows)))
|
||||||
|
p.add_metric("number of canisters", len(rows))
|
||||||
|
for row in rows:
|
||||||
|
if row.status != 'online':
|
||||||
|
p.status(critical)
|
||||||
|
p.add_summary("canister %s:%s is %s" % (row.enclosure_id, row.canister_id, row.status))
|
||||||
|
|
||||||
|
|
||||||
|
def check_lsenclosurepsu():
|
||||||
|
p.add_summary("%s psu found" % (len(rows)))
|
||||||
|
p.add_metric("number of psu", len(rows))
|
||||||
|
for row in rows:
|
||||||
|
if row.status != 'online':
|
||||||
|
p.status(critical)
|
||||||
|
p.add_summary("psu %s:%s is %s" % (row.enclosure_id, row.PSU_id, row.status))
|
||||||
|
|
||||||
|
|
||||||
|
def check_lsenclosure():
|
||||||
|
p.add_summary("%s enclosures found" % (len(rows)))
|
||||||
|
p.add_metric("number of enclosures", len(rows))
|
||||||
|
for row in rows:
|
||||||
|
if row.status != 'online':
|
||||||
|
p.status(critical)
|
||||||
|
p.add_summary("enclosure %s is %s" % (row.id, row.status))
|
||||||
|
|
||||||
|
|
||||||
|
def check_lsenclosureslot():
|
||||||
|
p.add_summary("%s slots found" % (len(rows)))
|
||||||
|
p.add_metric("number of slots", len(rows))
|
||||||
|
for row in rows:
|
||||||
|
if row.port_1_status != 'online':
|
||||||
|
p.status(critical)
|
||||||
|
p.add_summary("port1 on slot %s:%s is %s" % (row.enclosure_id, row.slot_id, row.port_1_status))
|
||||||
|
if row.port_2_status != 'online':
|
||||||
|
p.status(critical)
|
||||||
|
p.add_summary("port2 on slot %s:%s is %s" % (row.enclosure_id, row.slot_id, row.port_2_status))
|
||||||
|
|
||||||
|
|
||||||
|
def check_lsrcrelationship():
|
||||||
|
p.add_summary("%s cluster relationships found" % (len(rows)))
|
||||||
|
p.add_metric("number of relationships", len(rows))
|
||||||
|
for row in rows:
|
||||||
|
if row.state != 'consistent_synchronized':
|
||||||
|
p.status(critical)
|
||||||
|
p.add_summary("%s is %s" % (row.consistency_group_name, row.state))
|
||||||
|
|
||||||
|
|
||||||
|
def check_lsvdisk():
|
||||||
|
p.add_summary("%s disks found" % (len(rows)))
|
||||||
|
p.add_metric("number of disks", len(rows))
|
||||||
|
for row in rows:
|
||||||
|
if row.status != 'online':
|
||||||
|
p.status(critical)
|
||||||
|
p.add_summary("disk %s is %s" % (row.name, row.status))
|
||||||
|
|
||||||
|
|
||||||
|
def check_lsarray():
|
||||||
|
p.add_summary("%s arrays found" % (len(rows)))
|
||||||
|
p.add_metric("number of arrays", len(rows))
|
||||||
|
for row in rows:
|
||||||
|
if row.status != 'online':
|
||||||
|
p.add_summary("array %s is %s." % (row.mdisk_name, row.status))
|
||||||
|
p.status(critical)
|
||||||
|
if row.raid_status != 'online':
|
||||||
|
p.add_summary("array %s has raid status %s." % (row.mdisk_name, row.raid_status))
|
||||||
|
p.status(critical)
|
||||||
|
# Add some performance metrics
|
||||||
|
metric_name = row.mdisk_name + "_capacity"
|
||||||
|
p.add_metric(metric_name, value=row.capacity)
|
||||||
|
|
||||||
|
# Run our given query, and parse the output
|
||||||
|
rows = run_query()
|
||||||
|
|
||||||
|
if query == 'lsmdiskgrp':
|
||||||
|
check_lsmdiskgrp()
|
||||||
|
elif query == 'lsarray':
|
||||||
|
check_lsarray()
|
||||||
|
elif query == 'lsdrive':
|
||||||
|
check_lsdrive()
|
||||||
|
elif query == 'lsvdisk':
|
||||||
|
check_lsvdisk()
|
||||||
|
elif query == 'lsmgrp':
|
||||||
|
check_lsmgrp()
|
||||||
|
elif query == 'lsenclosure':
|
||||||
|
check_lsenclosure()
|
||||||
|
elif query == 'lsenclosurebattery':
|
||||||
|
check_lsenclosurebattery()
|
||||||
|
elif query == 'lsenclosurecanister':
|
||||||
|
check_lsenclosurecanister()
|
||||||
|
elif query == 'lsenclosurepsu':
|
||||||
|
check_lsenclosurepsu()
|
||||||
|
elif query == 'lsrcrelationship':
|
||||||
|
check_lsrcrelationship()
|
||||||
|
elif query == 'lsenclosureslot':
|
||||||
|
check_lsenclosureslot()
|
||||||
|
else:
|
||||||
|
p.status(unknown)
|
||||||
|
p.add_summary("unsupported query: %s. See -L for list of valid queries" % query)
|
||||||
|
p.exit()
|
||||||
|
|
||||||
|
# Check metrics and exit
|
||||||
|
p.check_all_metrics()
|
||||||
|
p.exit()
|
||||||
50
check_storwize/nagios-okplugin-check_storwize.spec
Normal file
50
check_storwize/nagios-okplugin-check_storwize.spec
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
%define debug_package %{nil}
|
||||||
|
%define plugin check_storwize
|
||||||
|
%define packager Pall Sigurdsson <palli@opensource.is>
|
||||||
|
|
||||||
|
Summary: A Nagios plugin to check status of a storwize disk array
|
||||||
|
Name: nagios-okplugin-%{plugin}
|
||||||
|
Version: 1.0.0
|
||||||
|
Release: 1%{?dist}
|
||||||
|
License: GPLv3+
|
||||||
|
Group: Applications/System
|
||||||
|
URL: https://github.com/opinkerfi/nagios-plugins/tree/master/%{plugin}
|
||||||
|
Source0: https://github.com/opinkerfi/nagios-plugins/tree/master/%{plugin}/releases/%{name}-%{version}.tar.gz
|
||||||
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
|
Packager: %{packager}
|
||||||
|
BuildArch: noarch
|
||||||
|
Requires: pynag
|
||||||
|
|
||||||
|
|
||||||
|
%description
|
||||||
|
Checks updates via PackageKit and can notify on various different situations
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%setup -q
|
||||||
|
|
||||||
|
%build
|
||||||
|
|
||||||
|
|
||||||
|
%install
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
install -D -p -m 0755 %{plugin} %{buildroot}%{_libdir}/nagios/plugins/%{plugin}
|
||||||
|
mkdir -p %{buildroot}%{_sysconfdir}/nrpe.d
|
||||||
|
sed "s^/usr/lib64^%{_libdir}^g" nrpe.d/%{plugin}.cfg > %{buildroot}%{_sysconfdir}/nrpe.d/%{plugin}.cfg
|
||||||
|
# Temporary fix for selinux
|
||||||
|
chcon system_u:object_r:nagios_unconfined_plugin_exec_t:s0 %{plugin} %{buildroot}%{_libdir}/nagios/plugins/%{plugin}
|
||||||
|
|
||||||
|
%clean
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
|
||||||
|
%post
|
||||||
|
/sbin/service nrpe status &> /dev/null && /sbin/service nrpe reload || :
|
||||||
|
|
||||||
|
%files
|
||||||
|
%defattr(-,root,root,-)
|
||||||
|
%doc README.md
|
||||||
|
%{_libdir}/nagios/plugins/*
|
||||||
|
%config(noreplace) %{_sysconfdir}/nrpe.d/%{plugin}.cfg
|
||||||
|
|
||||||
|
%changelog
|
||||||
|
* Fri Dec 6 2013 Pall Sigurdsson 1.0.0-1
|
||||||
|
- Initial Packaging
|
||||||
33
check_storwize/test.sh
Normal file
33
check_storwize/test.sh
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
CURRENT_PATH=`pwd`
|
||||||
|
cd $CURRENT_PATH/tests/ok
|
||||||
|
tests=`echo * | sed 's/.txt//g'`
|
||||||
|
for i in $tests ; do
|
||||||
|
command="python $CURRENT_PATH/check_storwize.py --test -H testhost -U nagios -Q $i"
|
||||||
|
$command > /dev/null 2>&1
|
||||||
|
RESULT=$?
|
||||||
|
if [ $RESULT -ne 0 ]; then
|
||||||
|
echo "FAIL"
|
||||||
|
echo "cd `pwd`"
|
||||||
|
echo "Command: $command"
|
||||||
|
else
|
||||||
|
echo "$i working as expected"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
|
cd $CURRENT_PATH/tests/critical
|
||||||
|
tests=`echo * | sed 's/.txt//g'`
|
||||||
|
for i in $tests ; do
|
||||||
|
command="python $CURRENT_PATH/check_storwize.py --test -H testhost -U nagios -Q $i"
|
||||||
|
$command > /dev/null 2>&1
|
||||||
|
RESULT=$?
|
||||||
|
if [ $RESULT -ne 2 ]; then
|
||||||
|
echo "FAIL"
|
||||||
|
echo "cd `pwd`"
|
||||||
|
echo "Command: $command"
|
||||||
|
else
|
||||||
|
echo "$i working as expected"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
@@ -2,13 +2,14 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to compare time on remote host with localhost
|
Summary: A Nagios plugin to compare time on remote host with localhost
|
||||||
Name: nagios-okplugin-check_time
|
Name: nagios-okplugin-check_time
|
||||||
Version: 1.0.1
|
Version: 1.0.3
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
URL: http://opensource.is/trac/wiki/check_time
|
URL: http://opensource.is/trac/wiki/check_time
|
||||||
Source0: http://opensource.ok.is/trac/browser/nagios-plugins/check_time/releases/nagios-okplugin-check_time-%{version}.tar.gz
|
Source0: http://opensource.ok.is/trac/browser/nagios-plugins/check_time/releases/nagios-okplugin-check_time-%{version}.tar.gz
|
||||||
Requires: nagios-nrpe
|
Requires: nagios-nrpe
|
||||||
|
Requires: bc
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
Packager: Pall Sigurdsson <palli@opensource.is>
|
Packager: Pall Sigurdsson <palli@opensource.is>
|
||||||
|
|
||||||
@@ -40,6 +41,12 @@ rm -rf %{buildroot}
|
|||||||
/etc/nrpe.d/check_time.cfg
|
/etc/nrpe.d/check_time.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri Apr 04 2014 Tomas Edwardsson <tommi@tommi.org> 1.0.3-1
|
||||||
|
- check_time - Added requirement for bc (tommi@tommi.org)
|
||||||
|
|
||||||
|
* Tue Mar 25 2014 Tomas Edwardsson <tommi@tommi.org> 1.0.2-1
|
||||||
|
- Bump version
|
||||||
|
|
||||||
* Mon Mar 12 2012 Pall Sigurdsson <palli@opensource.is> 1.0.1-1
|
* Mon Mar 12 2012 Pall Sigurdsson <palli@opensource.is> 1.0.1-1
|
||||||
- new package built with tito
|
- new package built with tito
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check uptime of a remote host via NRPE
|
Summary: A Nagios plugin to check uptime of a remote host via NRPE
|
||||||
Name: nagios-okplugin-check_uptime
|
Name: nagios-okplugin-check_uptime
|
||||||
Version: 1.0.1
|
Version: 1.0.3
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -41,6 +41,12 @@ rm -rf %{buildroot}
|
|||||||
/etc/nrpe.d/check_uptime.cfg
|
/etc/nrpe.d/check_uptime.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Sun Apr 13 2014 Tomas Edwardsson <tommi@tommi.org> 1.0.3-1
|
||||||
|
- Update tag
|
||||||
|
|
||||||
|
* Mon Dec 30 2013 Tomas Edwardsson <tommi@tommi.org> 1.0.2-1
|
||||||
|
- Updated tag for build with newer tito
|
||||||
|
|
||||||
* Mon Mar 12 2012 Pall Sigurdsson <palli@opensource.is> 1.0.1-1
|
* Mon Mar 12 2012 Pall Sigurdsson <palli@opensource.is> 1.0.1-1
|
||||||
- new package built with tito
|
- new package built with tito
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
Summary: A Nagios plugin to check yum updates via NRPE
|
Summary: A Nagios plugin to check yum updates via NRPE
|
||||||
Name: nagios-okplugin-check_yum
|
Name: nagios-okplugin-check_yum
|
||||||
Version: 0.8.2
|
Version: 1
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
Group: Applications/System
|
Group: Applications/System
|
||||||
@@ -45,6 +45,10 @@ rm -rf %{buildroot}
|
|||||||
/etc/nrpe.d/check_yum.cfg
|
/etc/nrpe.d/check_yum.cfg
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Feb 20 2014 Pall Sigurdsson <palli@opensource.is> 1-1
|
||||||
|
- Merge branch 'master' of github.com:opinkerfi/nagios-plugins
|
||||||
|
(palli@opensource.is)
|
||||||
|
|
||||||
* Mon May 27 2013 Tomas Edwardsson <tommi@tommi.org> 0.8.2-1
|
* Mon May 27 2013 Tomas Edwardsson <tommi@tommi.org> 0.8.2-1
|
||||||
- Fixed nrpe with invalid libdir (tommi@tommi.org)
|
- Fixed nrpe with invalid libdir (tommi@tommi.org)
|
||||||
|
|
||||||
|
|||||||
46
nagios-okplugin-common/nagios-okplugin-common.spec
Normal file
46
nagios-okplugin-common/nagios-okplugin-common.spec
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
%define debug_package %{nil}
|
||||||
|
|
||||||
|
Summary: A common package for the okplugin suite
|
||||||
|
Name: nagios-okplugin-common
|
||||||
|
Version: 1.2
|
||||||
|
Release: 1%{?dist}
|
||||||
|
License: GPLv2+
|
||||||
|
Group: Applications/System
|
||||||
|
URL: https://github.com/opinkerfi/nagios-plugins/
|
||||||
|
Source0: https://github.com/opinkerfi/nagios-plugins/archive/%{name}-%{version}-%{release}.tar.gz
|
||||||
|
Requires: nrpe
|
||||||
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
|
Packager: Tomas Edwardsson <tommi@ok.is>
|
||||||
|
BuildArch: noarch
|
||||||
|
|
||||||
|
%description
|
||||||
|
Common utilities for okplugins
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%setup -q
|
||||||
|
|
||||||
|
%build
|
||||||
|
|
||||||
|
|
||||||
|
%install
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
mkdir -m 0770 -p %{buildroot}%{_sharedstatedir}/nagios-okplugin
|
||||||
|
|
||||||
|
%clean
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
|
||||||
|
%post
|
||||||
|
|
||||||
|
%files
|
||||||
|
%defattr(-,root,root,-)
|
||||||
|
%dir %attr(0770, nrpe, nrpe) %{_sharedstatedir}/nagios-okplugin
|
||||||
|
|
||||||
|
%changelog
|
||||||
|
* Mon Jan 20 2014 Tomas Edwardsson <tommi@tommi.org> 1.2-1
|
||||||
|
-
|
||||||
|
|
||||||
|
* Mon Jan 20 2014 Tomas Edwardsson <tommi@tommi.org> 1.1-1
|
||||||
|
- new package built with tito
|
||||||
|
|
||||||
|
* Mon Jan 20 2014 Tomas Edwardsson <tommi@tommi.org> 1.0-1
|
||||||
|
- Initial build
|
||||||
46
okc-get_network_stat/nagios-okplugin-get_network_stat.spec
Normal file
46
okc-get_network_stat/nagios-okplugin-get_network_stat.spec
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
%define debug_package %{nil}
|
||||||
|
|
||||||
|
Summary: A Nagios plugin to get network statistics over NRPE
|
||||||
|
Name: nagios-okplugin-get_network_stat
|
||||||
|
Version: 1.0.1
|
||||||
|
Release: 1%{?dist}
|
||||||
|
License: GPLv2+
|
||||||
|
Group: Applications/System
|
||||||
|
URL: https://github.com/opinkerfi/nagios-plugins/okc-get_network_stat
|
||||||
|
Source0: https://github.com/opinkerfi/nagios-plugins/okc-get_network_stat/%{name}-%{version}.tar.gz
|
||||||
|
Requires: nagios-plugins-nrpe
|
||||||
|
BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||||
|
Packager: Tomas Edwardsson <tommi@tommi.org>
|
||||||
|
BuildArch: noarch
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
%description
|
||||||
|
A Nagios plugin to get network statistics over NRPE
|
||||||
|
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%setup -q
|
||||||
|
|
||||||
|
%build
|
||||||
|
|
||||||
|
|
||||||
|
%install
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
install -D -p -m 0755 okc-get_network_stat %{buildroot}%{_libdir}/nagios/plugins/okc-get_network_stat
|
||||||
|
|
||||||
|
%clean
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
|
||||||
|
%files
|
||||||
|
%defattr(-,root,root,-)
|
||||||
|
#%doc README LICENSE
|
||||||
|
#%{_libdir}/nagios/plugins/*
|
||||||
|
%{_libdir}/nagios/plugins/okc-get_network_stat
|
||||||
|
|
||||||
|
%changelog
|
||||||
|
* Wed Apr 02 2014 Tomas Edwardsson <tommi@tommi.org> 1.0.1-1
|
||||||
|
- new package built with tito
|
||||||
|
|
||||||
|
* Wed Apr 2 2014 Tomas Edwardsson <tommi@tommi.org> 1.0.0-1
|
||||||
|
- Initial release
|
||||||
65
okc-get_network_stat/okc-get_network_stat
Normal file
65
okc-get_network_stat/okc-get_network_stat
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
#!/usr/bin/python
|
||||||
|
|
||||||
|
from pynag.Plugins import PluginHelper, ok, warning, critical, unknown
|
||||||
|
from pynag.Utils import runCommand
|
||||||
|
import re
|
||||||
|
|
||||||
|
helper = PluginHelper()
|
||||||
|
|
||||||
|
helper.parser.add_option("-H", help="Host to connect to", dest="host", default='localhost')
|
||||||
|
|
||||||
|
helper.parse_arguments()
|
||||||
|
|
||||||
|
if helper.options.host == "localhost":
|
||||||
|
command="cat /proc/net/dev|sed 's/ */ /g'"
|
||||||
|
else:
|
||||||
|
command="/usr/lib64/nagios/plugins/check_nrpe -H '%s' -c get_network_interfaces_stat" % helper.options.host
|
||||||
|
|
||||||
|
return_code, stdout, stderr = runCommand(command)
|
||||||
|
|
||||||
|
try:
|
||||||
|
receive, transmit = stdout.split("\n")[1].split("|")[1:]
|
||||||
|
receive = receive.split()
|
||||||
|
transmit = transmit.split()
|
||||||
|
|
||||||
|
interfaces = []
|
||||||
|
|
||||||
|
for int_line in stdout.split("\n")[2:]:
|
||||||
|
int_line = int_line.strip()
|
||||||
|
if not int_line:
|
||||||
|
continue
|
||||||
|
|
||||||
|
int_arr = re.split("[: ]+", int_line.strip())
|
||||||
|
|
||||||
|
interface = int_arr.pop(0)
|
||||||
|
|
||||||
|
if interface == "lo" or interface.startswith('sit'):
|
||||||
|
continue
|
||||||
|
|
||||||
|
interfaces.append(interface)
|
||||||
|
for i in range(0, len(receive)):
|
||||||
|
helper.add_metric(
|
||||||
|
label="%s_rx_%s" % (interface, receive[i]),
|
||||||
|
value=int_arr.pop(0),
|
||||||
|
uom="c")
|
||||||
|
for i in range(0, len(transmit)):
|
||||||
|
helper.add_metric(
|
||||||
|
label="%s_tx_%s" % (interface, transmit[i]),
|
||||||
|
value=int_arr.pop(0),
|
||||||
|
uom="c")
|
||||||
|
|
||||||
|
helper.add_summary("Network interfaces %s" % ", ".join(interfaces))
|
||||||
|
|
||||||
|
# Here all metrics will be checked against thresholds that are either
|
||||||
|
# built-in or added via --threshold from the command-line
|
||||||
|
helper.check_all_metrics()
|
||||||
|
|
||||||
|
# Print out plugin information and exit nagios-style
|
||||||
|
helper.exit(ok)
|
||||||
|
except Exception, error:
|
||||||
|
helper.status(unknown)
|
||||||
|
helper.add_summary(stdout + stderr)
|
||||||
|
helper.exit(unknown)
|
||||||
|
|
||||||
|
# vim: sts=4 expandtab autoindent
|
||||||
|
|
||||||
@@ -1 +1 @@
|
|||||||
2.1.0-1 check_apcext.pl/
|
2.1.2-1 check_apcext.pl/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
0.0.3-1 check_bond/
|
0.0.4-1 check_bond/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
0.0.4-1 check_brocade/
|
0.0.5-1 check_brocade/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.0.1-1 check_dataprotector/
|
2-1 check_dataprotector/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.0.3-1 check_disks.pl/
|
1.0.7-1 check_disks.pl/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.0.2-1 check_eva/
|
2-1 check_eva/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.2-2 check_hpacucli/
|
2-1 check_hpacucli/
|
||||||
|
|||||||
1
rel-eng/packages/nagios-okplugin-check_hpasm
Normal file
1
rel-eng/packages/nagios-okplugin-check_hpasm
Normal file
@@ -0,0 +1 @@
|
|||||||
|
4.1.4-1 check_hpasm/
|
||||||
@@ -1 +1 @@
|
|||||||
1.1.2-3 check_ibm_bladecenter/
|
4-1 check_ibm_bladecenter/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.1.4-1 check_ironport/
|
2-1 check_ironport/
|
||||||
|
|||||||
1
rel-eng/packages/nagios-okplugin-check_msa_hardware
Normal file
1
rel-eng/packages/nagios-okplugin-check_msa_hardware
Normal file
@@ -0,0 +1 @@
|
|||||||
|
1.0.5-1 check_msa_hardware-pl/
|
||||||
@@ -1 +1 @@
|
|||||||
0.0.5-1 check_package_updates/
|
0.0.7-1 check_package_updates/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
0.0.4-1 check_rhcs/
|
1-1 check_rhcs/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.0.1-1 check_snmp/
|
2-1 check_snmp/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.0.1-1 check_time/
|
1.0.3-1 check_time/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.0.1-1 check_uptime/
|
1.0.3-1 check_uptime/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
0.8.2-1 check_yum/
|
1-1 check_yum/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.0-1 check_cifs/
|
1.1-1 check_cifs/
|
||||||
|
|||||||
1
rel-eng/packages/nagios-okplugin-get_network_stat
Normal file
1
rel-eng/packages/nagios-okplugin-get_network_stat
Normal file
@@ -0,0 +1 @@
|
|||||||
|
1.0.1-1 okc-get_network_stat/
|
||||||
@@ -1 +1 @@
|
|||||||
0.0.3-1 check_ipa/
|
0.0.4-1 check_ipa/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.0-1 check_bl/
|
1.1-1 check_bl/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.0-1 check_cpu.sh/
|
2-1 check_cpu.sh/
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
1.1-1 check_selinux/
|
1.3-1 check_selinux/
|
||||||
|
|||||||
@@ -1,36 +1,20 @@
|
|||||||
# Fedora FC18
|
# RHEL 7 Production
|
||||||
[test-fc18-x86_64]
|
[production-el7-x86_64]
|
||||||
releaser = tito.release.YumRepoReleaser
|
releaser = tito.release.YumRepoReleaser
|
||||||
builder = tito.builder.MockBuilder
|
builder = tito.builder.MockBuilder
|
||||||
builder.mock = fedora-18-x86_64
|
builder.mock = epel-7-x86_64
|
||||||
|
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/rhel7/x86_64/
|
||||||
|
|
||||||
|
# RHEL 7 Test
|
||||||
|
[test-el7-x86_64]
|
||||||
|
releaser = tito.release.YumRepoReleaser
|
||||||
|
builder = tito.builder.MockBuilder
|
||||||
|
builder.mock = epel-7-x86_64
|
||||||
builder.test = 1
|
builder.test = 1
|
||||||
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/testing/fedora18/x86_64/
|
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/testing/rhel7/x86_64/
|
||||||
|
|
||||||
|
|
||||||
[production-fc18-x86_64]
|
# RHEL 6 Production
|
||||||
releaser = tito.release.YumRepoReleaser
|
|
||||||
builder = tito.builder.MockBuilder
|
|
||||||
builder.mock = fedora-18-x86_64
|
|
||||||
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/fedora18/x86_64/
|
|
||||||
|
|
||||||
# Fedora FC17
|
|
||||||
[test-fc17-x86_64]
|
|
||||||
releaser = tito.release.YumRepoReleaser
|
|
||||||
builder = tito.builder.MockBuilder
|
|
||||||
builder.mock = fedora-17-x86_64
|
|
||||||
builder.test = 1
|
|
||||||
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/testing/fedora17/x86_64/
|
|
||||||
|
|
||||||
|
|
||||||
[production-fc17-x86_64]
|
|
||||||
releaser = tito.release.YumRepoReleaser
|
|
||||||
builder = tito.builder.MockBuilder
|
|
||||||
builder.mock = fedora-17-x86_64
|
|
||||||
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/fedora17/x86_64/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# RHEL 6
|
|
||||||
[production-el6-x86_64]
|
[production-el6-x86_64]
|
||||||
releaser = tito.release.YumRepoReleaser
|
releaser = tito.release.YumRepoReleaser
|
||||||
builder = tito.builder.MockBuilder
|
builder = tito.builder.MockBuilder
|
||||||
@@ -61,6 +45,21 @@ builder.mock = epel-5-i386
|
|||||||
createrepo_command = createrepo -s sha1 .
|
createrepo_command = createrepo -s sha1 .
|
||||||
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/rhel5/i386/
|
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/rhel5/i386/
|
||||||
|
|
||||||
|
# RHEL 6 Test
|
||||||
|
[test-el6-x86_64]
|
||||||
|
releaser = tito.release.YumRepoReleaser
|
||||||
|
builder = tito.builder.MockBuilder
|
||||||
|
builder.mock = epel-6-x86_64
|
||||||
|
builder.test = 1
|
||||||
|
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/testing/rhel6/x86_64/
|
||||||
|
|
||||||
|
[test-el6-i386]
|
||||||
|
releaser = tito.release.YumRepoReleaser
|
||||||
|
builder = tito.builder.MockBuilder
|
||||||
|
builder.mock = epel-6-i386
|
||||||
|
builder.test = 1
|
||||||
|
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/testing/rhel6/i386/
|
||||||
|
|
||||||
|
|
||||||
# RHEL 5 Testing
|
# RHEL 5 Testing
|
||||||
[test-el5-x86_64]
|
[test-el5-x86_64]
|
||||||
@@ -81,20 +80,22 @@ createrepo_command = createrepo -s sha1 .
|
|||||||
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/testing/rhel5/i386/
|
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/testing/rhel5/i386/
|
||||||
|
|
||||||
|
|
||||||
# RHEL 6 Test
|
|
||||||
[test-el6-x86_64]
|
|
||||||
releaser = tito.release.YumRepoReleaser
|
|
||||||
builder = tito.builder.MockBuilder
|
|
||||||
builder.mock = epel-6-x86_64
|
|
||||||
builder.test = 1
|
|
||||||
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/testing/rhel6/x86_64/
|
|
||||||
|
|
||||||
[test-el6-i386]
|
# Fedora FC20
|
||||||
|
[production-fc20-x86_64]
|
||||||
releaser = tito.release.YumRepoReleaser
|
releaser = tito.release.YumRepoReleaser
|
||||||
builder = tito.builder.MockBuilder
|
builder = tito.builder.MockBuilder
|
||||||
builder.mock = epel-6-i386
|
builder.mock = fedora-20-x86_64
|
||||||
|
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/fedora20/x86_64/
|
||||||
|
|
||||||
|
# Fedora FC20
|
||||||
|
[test-fc20-x86_64]
|
||||||
|
releaser = tito.release.YumRepoReleaser
|
||||||
|
builder = tito.builder.MockBuilder
|
||||||
|
builder.mock = fedora-20-x86_64
|
||||||
builder.test = 1
|
builder.test = 1
|
||||||
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/testing/rhel6/i386/
|
rsync = tito@opensource.is:/var/www/sites/opensource.ok.is/repo/testing/fedora20/x86_64/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user