Fix the heka grains for the aggregator/remote_collector
Previously, the heka salt grains of the node running aggregator/remote_collector
get all the metric_collector alarms from all nodes (/etc/salt/grains.d/heka).
The resulting mines data is then wrong for the monitoring node, while that
situtation fortunately has no impact regarding metric_collector alarm
configurations, the Nagios service leverging mine data get a wrong list of
alarms for the monitoring node.
This patch fixes the issue with minimal changes but it appears that the logic
behind _service.sls state is not optimal and become hard to understand.
This state is executed several times with different contexts for every heka
'server' types and is not indempotent, indeed the /etc/salt/grains.d/heka file
content is different between 'local' servers (metric|log)_collector and
'remote' servers remote_collector|aggregator.
diff --git a/heka/_service.sls b/heka/_service.sls
index 5749b2d..b990341 100644
--- a/heka/_service.sls
+++ b/heka/_service.sls
@@ -119,8 +119,6 @@
{# Loading the other services' support metadata for local roles #}
-{%- if service_name in ['log_collector', 'metric_collector'] %}
-
{%- for service_name, service in pillar.iteritems() %}
{%- if service.get('_support', {}).get('heka', {}).get('enabled', False) %}
@@ -131,23 +129,19 @@
{%- endif %}
{%- endfor %}
-{%- endif %}
-
-{%- if service_name in ['remote_collector', 'aggregator'] %}
-
-{# Load the support metadata from heka/meta/heka.yml #}
-
-{%- set grains_fragment_file = 'heka/meta/heka.yml' %}
-{%- set grains_yaml = load_grains_file(grains_fragment_file)|load_yaml %}
-{%- set service_grains = salt['grains.filter_by']({'default': service_grains}, merge=grains_yaml) %}
+{%- if service_name in ('remote_collector', 'aggregator') %}
{# Load the other services' support metadata from salt-mine #}
{%- for node_name, node_grains in salt['mine.get']('*', 'grains.items').iteritems() %}
{%- if node_grains.heka is defined %}
-{%- set service_grains = salt['grains.filter_by']({'default': service_grains}, merge=node_grains.heka) %}
-{%- endif %}
+{% for service, data in node_grains.heka.items() %}
+ {%- if service in ('remote_collector', 'aggregator') %}
+ {%- do salt['grains.filter_by']({'default': service_grains[service]}, merge=data) %}
+ {%- endif %}
+{% endfor %}
+{% endif %}
{%- endfor %}
{%- endif %}