From 9a8894bcabf6bdd9bbbb4aab9928dcd8dc22d0e2 Mon Sep 17 00:00:00 2001 From: Akash Suresh Date: Thu, 7 Mar 2019 12:14:37 -0500 Subject: [PATCH] Do not dispatch 0 value for non existent stats (#62) --- elasticsearch_collectd.py | 18 +++--------------- 1 file changed, 3 insertions(+), 15 deletions(-) diff --git a/elasticsearch_collectd.py b/elasticsearch_collectd.py index 203bc47..33ec7ce 100755 --- a/elasticsearch_collectd.py +++ b/elasticsearch_collectd.py @@ -948,13 +948,7 @@ def init_stats(self): def lookup_node_stat(self, stat, json): node = json['nodes'].keys()[0] val = dig_it_up(json, self.node_stats_cur[stat].path % node) - - # Check to make sure we have a valid result - # dig_it_up returns False if no match found - if not isinstance(val, bool): - return int(val) - else: - return None + return val def fetch_stats(self): """ @@ -1104,12 +1098,6 @@ def parse_thread_pool_stats(self, json, stats): if self.detailed_metrics is True or name in self.defaults: node = json['nodes'].keys()[0] result = dig_it_up(json, key.path % node) - # Check to make sure we have a valid result - # dig_it_up returns False if no match found - if not isinstance(result, bool): - result = int(result) - else: - result = None self.dispatch_stat(result, name, key, {'thread_pool': pool}) @@ -1144,7 +1132,7 @@ def dispatch_stat(self, result, name, key, dimensions=None): d=dimensions, r=result)) if result is None: - log.warning('Value not found for %s' % name) + log.debug('Value not found for %s' % name) return # If we failed to get the cluster name and do not have a config @@ -1210,7 +1198,7 @@ def dig_it_up(obj, path): path = path.split('.') return reduce(lambda x, y: x[y], path, obj) except: - return False + return None # The following classes are there to launch the plugin manually