From 02950e1bc9cfc7293204d37b8a4db1ada58713cc Mon Sep 17 00:00:00 2001 From: Leonardo Rossetti Date: Fri, 21 Apr 2017 11:31:29 -0300 Subject: [PATCH] gets memory from /proc/meminfo --- plugins/default/lib/memory_usage.py | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/plugins/default/lib/memory_usage.py b/plugins/default/lib/memory_usage.py index e096ac9..d7fa7ec 100755 --- a/plugins/default/lib/memory_usage.py +++ b/plugins/default/lib/memory_usage.py @@ -3,6 +3,7 @@ import sys import traceback from collections import Counter +import re import openshift import nagios @@ -27,11 +28,20 @@ def generate_parser(): ) return parser - -check_memory_usage_cmd = ("cat", "/sys/fs/cgroup/memory/memory.usage_in_bytes") +check_memory_usage_cmd = ("cat", "/proc/meminfo") check_memory_limit_cmd = ("cat", "/sys/fs/cgroup/memory/memory.limit_in_bytes") +def get_memfree(output): + data = None + try: + data = int(re.findall(r'MemFree\:\s+([0-9]+)\skB\n', output)[0]) * 1024 + except IndexError: + data = -1 + finally: + return data + + def analize(pod, container, memory_limit, memory_used, warning_threshold, critical_threshold): results = [] usage = (float(memory_used) / float(memory_limit)) * 100 @@ -103,6 +113,7 @@ def check(warn, crit, project): try: memory_usage = openshift.exec_in_pod_container( project, pod_name, container_name, check_memory_usage_cmd) + memory_usage = get_memfree(memory_usage) if memory_limit: memory_limit = openshift.exec_in_pod_container( project, pod_name, container_name, check_memory_limit_cmd)