check_esxi_hardware: Update to 20221230

This commit is contained in:
Jan Wagner 2024-03-08 13:56:10 +01:00
parent 65f532cb2f
commit 713d3fe45b
2 changed files with 69 additions and 19 deletions

View file

@ -22,7 +22,7 @@
# Copyright (c) 2008 David Ligeret # Copyright (c) 2008 David Ligeret
# Copyright (c) 2009 Joshua Daniel Franklin # Copyright (c) 2009 Joshua Daniel Franklin
# Copyright (c) 2010 Branden Schneider # Copyright (c) 2010 Branden Schneider
# Copyright (c) 2010-2021 Claudio Kuenzler # Copyright (c) 2010-2022 Claudio Kuenzler
# Copyright (c) 2010 Samir Ibradzic # Copyright (c) 2010 Samir Ibradzic
# Copyright (c) 2010 Aaron Rogers # Copyright (c) 2010 Aaron Rogers
# Copyright (c) 2011 Ludovic Hutin # Copyright (c) 2011 Ludovic Hutin
@ -38,6 +38,7 @@
# Copyright (c) 2015 Stefan Roos # Copyright (c) 2015 Stefan Roos
# Copyright (c) 2018 Peter Newman # Copyright (c) 2018 Peter Newman
# Copyright (c) 2020 Luca Berra # Copyright (c) 2020 Luca Berra
# Copyright (c) 2022 Marco Markgraf
# #
# The VMware 4.1 CIM API is documented here: # The VMware 4.1 CIM API is documented here:
# http://www.vmware.com/support/developer/cim-sdk/4.1/smash/cim_smash_410_prog.pdf # http://www.vmware.com/support/developer/cim-sdk/4.1/smash/cim_smash_410_prog.pdf
@ -284,7 +285,14 @@
#@ Author : Claudio Kuenzler #@ Author : Claudio Kuenzler
#@ Reason : Fix TLSv1 usage (issue #51) #@ Reason : Fix TLSv1 usage (issue #51)
#@--------------------------------------------------- #@---------------------------------------------------
#@ Date : 20220509
#@ Author : Marco Markgraf
#@ Reason : Added JSON-output (Zabbix needs it)
#@---------------------------------------------------
#@ Date : 20221230
#@ Author : Claudio Kuenzler
#@ Reason : Fix bug when missing S/N (issue #68)
#@---------------------------------------------------
from __future__ import print_function from __future__ import print_function
import sys import sys
@ -292,9 +300,10 @@ import time
import pywbem import pywbem
import re import re
import pkg_resources import pkg_resources
import json
from optparse import OptionParser,OptionGroup from optparse import OptionParser,OptionGroup
version = '20210809' version = '20221230'
NS = 'root/cimv2' NS = 'root/cimv2'
hosturl = '' hosturl = ''
@ -342,6 +351,7 @@ sensor_Type = {
} }
data = [] data = []
xdata = {}
perf_Prefix = { perf_Prefix = {
1:'Pow', 1:'Pow',
@ -373,6 +383,10 @@ vendor='unknown'
# verbose # verbose
verbose=False verbose=False
# output json
format='string'
pretty=False
# Produce performance data output for nagios # Produce performance data output for nagios
perfdata=False perfdata=False
@ -518,12 +532,20 @@ def verboseoutput(message) :
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
def xdataprint():
if format == 'json' and not pretty:
print(json.dumps(xdata, sort_keys=True))
if format == 'json' and pretty:
print(json.dumps(xdata, sort_keys=True, indent=4))
# ----------------------------------------------------------------------
def getopts() : def getopts() :
global hosturl,hostname,cimport,sslproto,user,password,vendor,verbose,perfdata,urlise_country,timeout,ignore_list,regex,get_power,get_volts,get_current,get_temp,get_fan,get_lcd,get_intrusion global hosturl,hostname,cimport,sslproto,user,password,vendor,verbose,perfdata,urlise_country,timeout,ignore_list,regex,get_power,get_volts,get_current,get_temp,get_fan,get_lcd,get_intrusion,format,pretty
usage = "usage: %prog -H hostname -U username -P password [-C port -S proto -V vendor -v -p -I XX -i list,list -r]\n" \ usage = "usage: %prog -H hostname -U username -P password [-C port -S proto -V vendor -v -p -I XX -i list,list -r]\n" \
"example: %prog -H hostname -U root -P password -C 5989 -V auto -I uk\n\n" \ "example: %prog -H hostname -U root -P password -C 5989 -V auto -I uk\n\n" \
"or, verbosely:\n\n" \ "or, verbosely:\n\n" \
"usage: %prog --host=hostname --user=username --pass=password [--cimport=port --sslproto=version --vendor=system --verbose --perfdata --html=XX]\n" "usage: %prog --host=hostname --user=username --pass=password [--cimport=port --sslproto=version --vendor=system --verbose --perfdata --html=XX --format=json --pretty]\n"
parser = OptionParser(usage=usage, version="%prog "+version) parser = OptionParser(usage=usage, version="%prog "+version)
group1 = OptionGroup(parser, 'Mandatory parameters') group1 = OptionGroup(parser, 'Mandatory parameters')
@ -564,6 +586,10 @@ def getopts() :
help="don't collect lcd/front display status") help="don't collect lcd/front display status")
group2.add_option("--no-intrusion", action="store_false", dest="get_intrusion", default=True, \ group2.add_option("--no-intrusion", action="store_false", dest="get_intrusion", default=True, \
help="don't collect chassis intrusion status") help="don't collect chassis intrusion status")
group2.add_option("--format", dest="format", help="'string' (default) or 'json'", \
metavar="FORMAT", type='choice', choices=['string','json'],default="string")
group2.add_option("--pretty", action="store_true", dest="pretty", default=False, \
help="return data as a pretty-printed json-array")
parser.add_option_group(group1) parser.add_option_group(group1)
parser.add_option_group(group2) parser.add_option_group(group2)
@ -610,14 +636,16 @@ def getopts() :
user=options.user user=options.user
password=options.password password=options.password
cimport=options.cimport cimport=options.cimport
ignore_list=options.ignore.split(',')
format=options.format
pretty=options.pretty
perfdata=options.perfdata
regex=options.regex
sslproto=options.sslproto sslproto=options.sslproto
timeout=options.timeout
urlise_country=options.urlise_country.lower()
vendor=options.vendor.lower() vendor=options.vendor.lower()
verbose=options.verbose verbose=options.verbose
perfdata=options.perfdata
urlise_country=options.urlise_country.lower()
timeout=options.timeout
ignore_list=options.ignore.split(',')
regex=options.regex
get_power=options.get_power get_power=options.get_power
get_volts=options.get_volts get_volts=options.get_volts
get_current=options.get_current get_current=options.get_current
@ -778,7 +806,7 @@ for classe in ClassesToCheck :
verboseoutput("Check classe "+classe) verboseoutput("Check classe "+classe)
try: try:
instance_list = wbemclient.EnumerateInstances(classe) instance_list = wbemclient.EnumerateInstances(classe)
except pywbem.cim_operations.CIMError as args: except pywbem._cim_operations.CIMError as args:
if ( args[1].find('Socket error') >= 0 ): if ( args[1].find('Socket error') >= 0 ):
print("UNKNOWN: {}".format(args)) print("UNKNOWN: {}".format(args))
sys.exit (ExitUnknown) sys.exit (ExitUnknown)
@ -791,7 +819,7 @@ for classe in ClassesToCheck :
GlobalStatus = ExitUnknown GlobalStatus = ExitUnknown
print("UNKNOWN: {}".format(args)) print("UNKNOWN: {}".format(args))
sys.exit (GlobalStatus) sys.exit (GlobalStatus)
except pywbem.cim_http.AuthError as arg: except pywbem._cim_http.AuthError as arg:
verboseoutput("Global exit set to UNKNOWN") verboseoutput("Global exit set to UNKNOWN")
GlobalStatus = ExitUnknown GlobalStatus = ExitUnknown
print("UNKNOWN: Authentication Error") print("UNKNOWN: Authentication Error")
@ -823,6 +851,8 @@ for classe in ClassesToCheck :
+ str(instance[u'ReleaseDate'].datetime.date()) + str(instance[u'ReleaseDate'].datetime.date())
verboseoutput(" VersionString = "+instance[u'VersionString']) verboseoutput(" VersionString = "+instance[u'VersionString'])
xdata['Bios Info'] = bios_info
elif elementName == 'Chassis' : elif elementName == 'Chassis' :
man = instance[u'Manufacturer'] man = instance[u'Manufacturer']
if man is None : if man is None :
@ -837,7 +867,7 @@ for classe in ClassesToCheck :
model = instance[u'Model'] model = instance[u'Model']
if model: if model:
verboseoutput(" Model = "+model) verboseoutput(" Model = "+model)
server_info += model + ' s/n:' server_info += model
elif elementName == 'Server Blade' : elif elementName == 'Server Blade' :
SerialNumber = instance[u'SerialNumber'] SerialNumber = instance[u'SerialNumber']
@ -845,6 +875,8 @@ for classe in ClassesToCheck :
verboseoutput(" SerialNumber = "+SerialNumber) verboseoutput(" SerialNumber = "+SerialNumber)
isblade = "yes" isblade = "yes"
xdata['SerialNumber'] = SerialNumber
# Report detail of Numeric Sensors and generate nagios perfdata # Report detail of Numeric Sensors and generate nagios perfdata
if classe == "CIM_NumericSensor" : if classe == "CIM_NumericSensor" :
@ -886,27 +918,33 @@ for classe in ClassesToCheck :
if units == 7: # Watts if units == 7: # Watts
if get_power: if get_power:
data.append( ("%s=%g;%g;%g " % (perf_el, cr, utnc, utc),1) ) data.append( ("%s=%g;%g;%g " % (perf_el, cr, utnc, utc),1) )
xdata[perf_el] = { 'Unit': 'Watt', 'Value': cr, 'warn' : utnc, 'crit': utc }
elif units == 6: # Current elif units == 6: # Current
if get_current: if get_current:
data.append( ("%s=%g;%g;%g " % (perf_el, cr, utnc, utc),3) ) data.append( ("%s=%g;%g;%g " % (perf_el, cr, utnc, utc),3) )
xdata[perf_el] = { 'Unit': 'Ampere', 'Value': cr, 'warn' : utnc, 'crit': utc }
# PSU Voltage # PSU Voltage
elif sensorType == 3: # Voltage elif sensorType == 3: # Voltage
if get_volts: if get_volts:
data.append( ("%s=%g;%g;%g " % (perf_el, cr, utnc, utc),2) ) data.append( ("%s=%g;%g;%g " % (perf_el, cr, utnc, utc),2) )
xdata[perf_el] = { 'Unit': 'Volt', 'Value': cr, 'warn' : utnc, 'crit': utc }
# Temperatures # Temperatures
elif sensorType == 2: # Temperature elif sensorType == 2: # Temperature
if get_temp: if get_temp:
data.append( ("%s=%g;%g;%g " % (perf_el, cr, utnc, utc),4) ) data.append( ("%s=%g;%g;%g " % (perf_el, cr, utnc, utc),4) )
xdata[perf_el] = { 'Value': cr, 'warn' : utnc, 'crit': utc }
# Fan speeds # Fan speeds
elif sensorType == 5: # Tachometer elif sensorType == 5: # Tachometer
if get_fan: if get_fan:
if units == 65: # percentage if units == 65: # percentage
data.append( ("%s=%g%%;%g;%g " % (perf_el, cr, utnc, utc),6) ) data.append( ("%s=%g%%;%g;%g " % (perf_el, cr, utnc, utc),6) )
xdata[perf_el] = { 'Unit': '%', 'Value': cr, 'warn' : utnc, 'crit': utc }
else: else:
data.append( ("%s=%g;%g;%g " % (perf_el, cr, utnc, utc),5) ) data.append( ("%s=%g;%g;%g " % (perf_el, cr, utnc, utc),5) )
xdata[perf_el] = { 'Value': cr, 'warn' : utnc, 'crit': utc }
elif classe == "CIM_Processor" : elif classe == "CIM_Processor" :
verboseoutput(" Family = %d" % instance['Family']) verboseoutput(" Family = %d" % instance['Family'])
@ -1002,6 +1040,7 @@ if (urlise_country != '') :
# If this is a blade server, also output chassis serial number as additional info # If this is a blade server, also output chassis serial number as additional info
if (isblade == "yes") : if (isblade == "yes") :
SerialNumber += " Chassis S/N: %s " % (SerialChassis) SerialNumber += " Chassis S/N: %s " % (SerialChassis)
xdata['ChassisSerialNumber'] = SerialChassis
# Output performance data # Output performance data
perf = '|' perf = '|'
@ -1027,13 +1066,24 @@ if perf == '|':
if sslproto: if sslproto:
os.remove(sslconfpath) os.remove(sslconfpath)
xdata['GlobalStatus'] = GlobalStatus
if GlobalStatus == ExitOK : if GlobalStatus == ExitOK :
print("OK - Server: %s %s %s%s" % (server_info, SerialNumber, bios_info, perf)) if format == 'string':
print("OK - Server: %s s/n: %s %s%s" % (server_info, SerialNumber, bios_info, perf))
else:
xdataprint()
elif GlobalStatus == ExitUnknown : elif GlobalStatus == ExitUnknown :
if format == 'string':
print("UNKNOWN: %s" % (ExitMsg)) #ARR print("UNKNOWN: %s" % (ExitMsg)) #ARR
else:
xdataprint()
else: else:
print("%s - Server: %s %s %s%s" % (ExitMsg, server_info, SerialNumber, bios_info, perf)) if format == 'string':
print("%s - Server: %s %s %s%s" % (ExitMsg, server_info, 's/n: ' + SerialNumber, bios_info, perf))
else:
xdataprint()
sys.exit (GlobalStatus) sys.exit (GlobalStatus)

View file

@ -1,6 +1,6 @@
Uploaders: Jan Wagner <waja@cyconet.org> Uploaders: Jan Wagner <waja@cyconet.org>
Recommends: python3-minimal, python-pywbem Recommends: python3-minimal, python-pywbem
Version: 20210809 Version: 20221230
Homepage: https://github.com/Napsty/check_esxi_hardware Homepage: https://github.com/Napsty/check_esxi_hardware
Watch: https://github.com/Napsty/check_esxi_hardware/tags .*/v?(\d\S+)\.tar\.gz Watch: https://github.com/Napsty/check_esxi_hardware/tags .*/v?(\d\S+)\.tar\.gz
Description: Plugin for checking global health of VMware ESX/ESXi host Description: Plugin for checking global health of VMware ESX/ESXi host