Configure ceilometer coordination backend_url
Add ability to configure ceilometer coordination backend_url from
coordination_backend:redis pillar if enabled
Related-Prod: PROD-29126
Change-Id: I97acb85ae93300102d50dbbd9eb89597b6f1e666
(cherry picked from commit 919b17760bbe1d5553dd3dcf7702ad5a8cb844ff)
Change-Id: I97acb85ae93300102d50dbbd9eb89597b6f1e666
diff --git a/README.rst b/README.rst
index 0bc8d4b..ae4d984 100644
--- a/README.rst
+++ b/README.rst
@@ -369,7 +369,24 @@
cert_file: (certificate path)
key_file: (key path)
+Setup redis coordination_backend url:
+---------------------------
+.. code-block:: yaml
+ ceilometer:
+ server:
+ coordination_backend:
+ engine: redis
+ redis:
+ password: pswd
+ user: openstack
+ db: '0'
+ sentinel:
+ host: 127.0.0.1
+ master_name: master_1
+ fallback:
+ - host: 127.0.1.1
+ - host: 127.0.2.1
More Information
================
diff --git a/ceilometer/files/mitaka/ceilometer-server.conf.Debian b/ceilometer/files/mitaka/ceilometer-server.conf.Debian
index 79cb291..61ac78f 100644
--- a/ceilometer/files/mitaka/ceilometer-server.conf.Debian
+++ b/ceilometer/files/mitaka/ceilometer-server.conf.Debian
@@ -140,8 +140,19 @@
# partitioning and will only function correctly if a single instance of that
# service is running. (string value)
{%- if server.coordination_backend is defined %}
+{%- if server.coordination_backend.redis is defined and server.coordination_backend.get('engine', redis) == 'redis' %}
+ {%- set conn = server.coordination_backend.redis %}
+ {%- if conn.sentinel is defined %}
+backend_url = {{ conn.get('scheme', 'redis') }}://{{ conn.user }}:{{ conn.password }}@{{ conn.sentinel.host }}:{{ conn.sentinel.get('port', '26379') }}?sentinel={{ conn.sentinel.master_name }}{%
+ if conn.db is defined -%}&db={{ conn.db }}{% endif -%}{%
+ if conn.sentinel.fallback is defined %}{% for member in conn.sentinel.fallback -%}&sentinel_fallback={{ member.host }}:{{ member.get('port', '26379') }}{%- endfor -%}{% endif -%}
+ {%- else %}
+backend_url = {{ conn.get('scheme', 'redis') }}://{{ conn.user }}:{{ conn.password }}@{{ conn.host }}:{{ conn.get('port', '6379') }}{% if conn.db is defined -%}?db={{ conn.db }}{% endif -%}
+ {%- endif %}
+{%- elif server.coordination_backend.url is defined %}
backend_url = {{ server.coordination_backend.url }}
-{%- endif %}
+{%- endif %}
+{%- endif %}
# Number of seconds between heartbeats for distributed coordination. (floating
# point value)
@@ -526,4 +537,4 @@
#allow_headers = X-Auth-Token,X-Openstack-Request-Id,X-Subject-Token,X-Project-Id,X-Project-Name,X-Project-Domain-Id,X-Project-Domain-Name,X-Domain-Id,X-Domain-Name
{% if server.get('cors', {}).allow_headers is defined %}
allow_headers = {{ server.cors.allow_headers }}
-{% endif %}
\ No newline at end of file
+{% endif %}
diff --git a/ceilometer/files/ocata/ceilometer-server.conf.Debian b/ceilometer/files/ocata/ceilometer-server.conf.Debian
index 8619648..c726424 100644
--- a/ceilometer/files/ocata/ceilometer-server.conf.Debian
+++ b/ceilometer/files/ocata/ceilometer-server.conf.Debian
@@ -608,6 +608,20 @@
# partitioning and will only function correctly if a single instance of that
# service is running. (string value)
#backend_url = <None>
+{%- if server.coordination_backend is defined %}
+{%- if server.coordination_backend.redis is defined and server.coordination_backend.get('engine', redis) == 'redis' %}
+ {%- set conn = server.coordination_backend.redis %}
+ {%- if conn.sentinel is defined %}
+backend_url = {{ conn.get('scheme', 'redis') }}://{{ conn.user }}:{{ conn.password }}@{{ conn.sentinel.host }}:{{ conn.sentinel.get('port', '26379') }}?sentinel={{ conn.sentinel.master_name }}{%
+ if conn.db is defined -%}&db={{ conn.db }}{% endif -%}{%
+ if conn.sentinel.fallback is defined %}{% for member in conn.sentinel.fallback -%}&sentinel_fallback={{ member.host }}:{{ member.get('port', '26379') }}{%- endfor -%}{% endif -%}
+ {%- else %}
+backend_url = {{ conn.get('scheme', 'redis') }}://{{ conn.user }}:{{ conn.password }}@{{ conn.host }}:{{ conn.get('port', '6379') }}{% if conn.db is defined -%}?db={{ conn.db }}{% endif -%}
+ {%- endif %}
+{%- elif server.coordination_backend.url is defined %}
+backend_url = {{ server.coordination_backend.url }}
+{%- endif %}
+{%- endif %}
# Number of seconds between heartbeats for distributed coordination. (floating
# point value)
diff --git a/ceilometer/files/pike/ceilometer-server.conf.Debian b/ceilometer/files/pike/ceilometer-server.conf.Debian
index a88721e..3ab3626 100644
--- a/ceilometer/files/pike/ceilometer-server.conf.Debian
+++ b/ceilometer/files/pike/ceilometer-server.conf.Debian
@@ -33,8 +33,19 @@
{%- if server.coordination_backend is defined %}
+{%- if server.coordination_backend.redis is defined and server.coordination_backend.get('engine', redis) == 'redis' %}
+ {%- set conn = server.coordination_backend.redis %}
+ {%- if conn.sentinel is defined %}
+backend_url = {{ conn.get('scheme', 'redis') }}://{{ conn.user }}:{{ conn.password }}@{{ conn.sentinel.host }}:{{ conn.sentinel.get('port', '26379') }}?sentinel={{ conn.sentinel.master_name }}{%
+ if conn.db is defined -%}&db={{ conn.db }}{% endif -%}{%
+ if conn.sentinel.fallback is defined %}{% for member in conn.sentinel.fallback -%}&sentinel_fallback={{ member.host }}:{{ member.get('port', '26379') }}{%- endfor -%}{% endif -%}
+ {%- else %}
+backend_url = {{ conn.get('scheme', 'redis') }}://{{ conn.user }}:{{ conn.password }}@{{ conn.host }}:{{ conn.get('port', '6379') }}{% if conn.db is defined -%}?db={{ conn.db }}{% endif -%}
+ {%- endif %}
+{%- elif server.coordination_backend.url is defined %}
backend_url = {{ server.coordination_backend.url }}
-{%- endif %}
+{%- endif %}
+{%- endif %}
{%- if server.get('coordination_backend', {}).heartbeat is defined %}
heartbeat = {{ server.coordination_backend.heartbeat }}
diff --git a/ceilometer/files/queens/ceilometer-server.conf.Debian b/ceilometer/files/queens/ceilometer-server.conf.Debian
index 8b6e033..5054c06 100644
--- a/ceilometer/files/queens/ceilometer-server.conf.Debian
+++ b/ceilometer/files/queens/ceilometer-server.conf.Debian
@@ -91,8 +91,19 @@
# service is running. (string value)
#backend_url = <None>
{%- if server.coordination_backend is defined %}
+{%- if server.coordination_backend.redis is defined and server.coordination_backend.get('engine', redis) == 'redis' %}
+ {%- set conn = server.coordination_backend.redis %}
+ {%- if conn.sentinel is defined %}
+backend_url = {{ conn.get('scheme', 'redis') }}://{{ conn.user }}:{{ conn.password }}@{{ conn.sentinel.host }}:{{ conn.sentinel.get('port', '26379') }}?sentinel={{ conn.sentinel.master_name }}{%
+ if conn.db is defined -%}&db={{ conn.db }}{% endif -%}{%
+ if conn.sentinel.fallback is defined %}{% for member in conn.sentinel.fallback -%}&sentinel_fallback={{ member.host }}:{{ member.get('port', '26379') }}{%- endfor -%}{% endif -%}
+ {%- else %}
+backend_url = {{ conn.get('scheme', 'redis') }}://{{ conn.user }}:{{ conn.password }}@{{ conn.host }}:{{ conn.get('port', '6379') }}{% if conn.db is defined -%}?db={{ conn.db }}{% endif -%}
+ {%- endif %}
+{%- elif server.coordination_backend.url is defined %}
backend_url = {{ server.coordination_backend.url }}
-{%- endif %}
+{%- endif %}
+{%- endif %}
# Number of seconds between checks to see if group membership has changed
# (floating point value)
diff --git a/tests/pillar/server_cluster.sls b/tests/pillar/server_cluster.sls
index be5f1bb..db6ce31 100644
--- a/tests/pillar/server_cluster.sls
+++ b/tests/pillar/server_cluster.sls
@@ -59,6 +59,19 @@
enabled: true
host: 127.0.0.4
port: 8086
+ coordination_backend:
+ url: 'redis://127.0.0.1/test'
+ engine: redis
+ redis:
+ password: pswd
+ user: openstack
+ db: '0'
+ sentinel:
+ host: 127.0.0.1
+ master_name: master_1
+ fallback:
+ - host: 127.0.1.1
+ - host: 127.0.2.1
notification:
workers: 8
batch_timeout: 10