Module: check_mk
Branch: master
Commit: 88453696a6c0814e09ef48997cc5da3f29db8ce3
URL:
http://git.mathias-kettner.de/git/?p=check_mk.git;a=commit;h=88453696a6c081…
Author: Marcel Arentz <ma(a)mathias-kettner.de>
Date: Thu Apr 27 11:19:37 2017 +0200
4639 bintec_cpu: Added CPU utilization to bintec devices
Change-Id: I07132514e039a41bac5a335fceaf6379263a7f3c
---
.werks/4639 | 10 ++++++
checkman/bintec_cpu | 12 ++++++++
checks/bintec_cpu | 68 +++++++++++++++++++++++++++++++++++++++++
web/plugins/metrics/check_mk.py | 12 ++++++++
4 files changed, 102 insertions(+)
diff --git a/.werks/4639 b/.werks/4639
new file mode 100644
index 0000000..f088c3a
--- /dev/null
+++ b/.werks/4639
@@ -0,0 +1,10 @@
+Title: bintec_cpu: Added CPU utilization to bintec devices
+Level: 1
+Component: checks
+Compatible: compat
+Edition: cre
+Version: 1.5.0i1
+Date: 1493284746
+Class: feature
+
+
diff --git a/checkman/bintec_cpu b/checkman/bintec_cpu
new file mode 100644
index 0000000..3d5412a
--- /dev/null
+++ b/checkman/bintec_cpu
@@ -0,0 +1,12 @@
+title: Bintec Devices: CPU Utilization
+agents: snmp
+catalog: os/kernel
+license: GPL
+distribution: check_mk
+description:
+ This check measures the CPU utilization during the last check cycle. Levels can
+ be set on the total utilization. Additionally levels can be set for a high
+ utilization over an extended period of time.
+
+inventory:
+ Creates one check per host if the data is provided by device
diff --git a/checks/bintec_cpu b/checks/bintec_cpu
new file mode 100644
index 0000000..693eb4d
--- /dev/null
+++ b/checks/bintec_cpu
@@ -0,0 +1,68 @@
+#!/usr/bin/python
+# -*- encoding: utf-8; py-indent-offset: 4 -*-
+# +------------------------------------------------------------------+
+# | ____ _ _ __ __ _ __ |
+# | / ___| |__ ___ ___| | __ | \/ | |/ / |
+# | | | | '_ \ / _ \/ __| |/ / | |\/| | ' / |
+# | | |___| | | | __/ (__| < | | | | . \ |
+# | \____|_| |_|\___|\___|_|\_\___|_| |_|_|\_\ |
+# | |
+# | Copyright Mathias Kettner 2016 mk(a)mathias-kettner.de |
+# +------------------------------------------------------------------+
+#
+# This file is part of Check_MK.
+# The official homepage is at
http://mathias-kettner.de/check_mk.
+#
+# check_mk 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 in version 2. check_mk is distributed
+# in the hope that it will be useful, but WITHOUT ANY WARRANTY; with-
+# out even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE. See the GNU General Public License for more de-
+# tails. You should have received a copy of the GNU General Public
+# License along with GNU Make; see the file COPYING. If not, write
+# to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
+# Boston, MA 02110-1301 USA.
+
+
+# Diese OIDs liefern nicht die LOAD, wie man annehmen könnte, sondern die
+# UTILIZATION, da ausschließlich die Auslastung der CPU berücksichtigt wird.
+# .1.3.6.1.4.1.272.4.17.4.1.1.15.1.0 5 -->
BIANCA-BRICK-MIBRES-MIB::CpuLoadUser60s.1.0
+# .1.3.6.1.4.1.272.4.17.4.1.1.16.1.0 1 -->
BIANCA-BRICK-MIBRES-MIB::CpuLoadSystem60s.1.0
+# .1.3.6.1.4.1.272.4.17.4.1.1.17.1.0 9 -->
BIANCA-BRICK-MIBRES-MIB::CpuLoadStreams60s.1.0
+
+
+def inventory_bintec_cpu(info):
+ if info:
+ return [(None, {})]
+
+
+def check_bintec_cpu(_no_item, params, info):
+ user = float(info[0][0])
+ system = float(info[0][1])
+ streams = float(info[0][2])
+ util = user + system + streams
+
+ for res in check_cpu_util(util, params):
+ state, infotext, perfdata = res
+ #print
+ yield state, "total: %s" % infotext, perfdata
+
+ yield 0, "user: %.1f%%, system: %.1f%%, streams: %.1f%%" % \
+ (user, system, streams), [ ("streams", "%.3f" %
streams), ]
+
+
+check_info['bintec_cpu'] = {
+ 'inventory_function' : inventory_bintec_cpu,
+ 'check_function' : check_bintec_cpu,
+ 'service_description' : 'CPU utilization',
+ 'snmp_info' : ('.1.3.6.1.4.1.272.4.17.4.1.1', [
+ "15", # cpuLoadUser60s
+ "16", # cpuLoadSystem60s
+ "17", # cpuLoadStreams60s
+ ]),
+ 'snmp_scan_function' : lambda oid:
oid(".1.3.6.1.2.1.1.2.0").startswith(".1.3.6.1.4.1.272.4."),
+ 'has_perfdata' : True,
+ 'group' : 'cpu_utilization_os',
+ 'includes' : [ 'cpu_util.include' ],
+}
diff --git a/web/plugins/metrics/check_mk.py b/web/plugins/metrics/check_mk.py
index fe22acb..fae8c2c 100644
--- a/web/plugins/metrics/check_mk.py
+++ b/web/plugins/metrics/check_mk.py
@@ -375,6 +375,12 @@ metric_info["lifetime_remaining"] = {
"color" : "#80f000",
}
+metric_info["streams"] = {
+ "title" : _("Streams"),
+ "unit" : "%",
+ "color" : "35/a",
+}
+
metric_info["cache_hit_ratio"] = {
"title" : _("Cache hit ratio"),
"unit" : "%",
@@ -5126,6 +5132,12 @@ perfometer_info.append({
perfometer_info.append({
"type" : "linear",
+ "segments" : [ "user", "system", "streams"
],
+ "total" : 100.0,
+})
+
+perfometer_info.append({
+ "type" : "linear",
"segments" : [ "citrix_load" ],
"total" : 100.0,
})