From 14ab9a7c4e752aa25ebcc077d7a4a86d5c166d78 Mon Sep 17 00:00:00 2001 From: Erol Guzoglu Date: Tue, 5 Mar 2019 16:21:08 +0300 Subject: [PATCH] Support the prometheus elasticsearch exporter This patch implements the support for the elasticsearch-exporter in kolla-ansible The configuration and prechecks are reused from the other exporters Depends-On: Id138f12e10102a6dd2cd8d84f2cc47aa29af3972 Change-Id: Iae0eac0179089f159804490bf71f1cf2c38dde54 --- ansible/group_vars/all.yml | 3 +++ ansible/inventory/all-in-one | 3 +++ ansible/inventory/multinode | 3 +++ ansible/roles/prometheus/defaults/main.yml | 15 +++++++++++++ ansible/roles/prometheus/handlers/main.yml | 21 +++++++++++++++++++ ansible/roles/prometheus/tasks/precheck.yml | 15 +++++++++++++ .../prometheus-elasticsearch-exporter.json.j2 | 11 ++++++++++ .../prometheus/templates/prometheus.yml.j2 | 10 +++++++++ ansible/site.yml | 1 + etc/kolla/globals.yml | 1 + ...asticsearch-exporter-4d9b75b5cb8801d1.yaml | 5 +++++ tests/templates/inventory.j2 | 3 +++ 12 files changed, 91 insertions(+) create mode 100644 ansible/roles/prometheus/templates/prometheus-elasticsearch-exporter.json.j2 create mode 100644 releasenotes/notes/add-prometheus-elasticsearch-exporter-4d9b75b5cb8801d1.yaml diff --git a/ansible/group_vars/all.yml b/ansible/group_vars/all.yml index d96e7acab2..7d14bae1ae 100644 --- a/ansible/group_vars/all.yml +++ b/ansible/group_vars/all.yml @@ -321,6 +321,7 @@ prometheus_alertmanager_cluster_port: "9094" # Prometheus openstack-exporter ports prometheus_openstack_exporter_port: "9198" +prometheus_elasticsearch_exporter_port: "9108" qdrouterd_port: "31459" @@ -946,9 +947,11 @@ enable_prometheus_cadvisor: "{{ enable_prometheus | bool }}" enable_prometheus_alertmanager: "{{ enable_prometheus | bool }}" enable_prometheus_ceph_mgr_exporter: "{{ enable_ceph | bool and enable_prometheus | bool }}" enable_prometheus_openstack_exporter: "{{ enable_prometheus | bool }}" +enable_prometheus_elasticsearch_exporter: "{{ enable_prometheus | bool and enable_elasticsearch | bool }}" prometheus_alertmanager_user: "admin" prometheus_openstack_exporter_interval: "60s" +prometheus_elasticsearch_exporter_interval: "60s" ############ # Vitrage diff --git a/ansible/inventory/all-in-one b/ansible/inventory/all-in-one index 27b284220f..ced3eee5f4 100644 --- a/ansible/inventory/all-in-one +++ b/ansible/inventory/all-in-one @@ -732,3 +732,6 @@ monitoring [prometheus-openstack-exporter:children] monitoring + +[prometheus-elasticsearch-exporter:children] +elasticsearch diff --git a/ansible/inventory/multinode b/ansible/inventory/multinode index 2d84051537..19f37d0c55 100644 --- a/ansible/inventory/multinode +++ b/ansible/inventory/multinode @@ -751,3 +751,6 @@ monitoring [prometheus-openstack-exporter:children] monitoring + +[prometheus-elasticsearch-exporter:children] +elasticsearch diff --git a/ansible/roles/prometheus/defaults/main.yml b/ansible/roles/prometheus/defaults/main.yml index cdde13d703..6b53c4074c 100644 --- a/ansible/roles/prometheus/defaults/main.yml +++ b/ansible/roles/prometheus/defaults/main.yml @@ -115,6 +115,16 @@ prometheus_services: - "kolla_logs:/var/log/kolla/" - "prometheus:/var/lib/prometheus" dimensions: "{{ prometheus_openstack_exporter_dimensions }}" + prometheus-elasticsearch-exporter: + container_name: prometheus_elasticsearch_exporter + group: prometheus-elasticsearch-exporter + enabled: "{{ enable_prometheus_elasticsearch_exporter | bool }}" + image: "{{ prometheus_elasticsearch_exporter_image_full }}" + volumes: + - "{{ node_config_directory }}/prometheus-elasticsearch-exporter/:{{ container_config_directory }}/:ro" + - "/etc/localtime:/etc/localtime:ro" + - "kolla_logs:/var/log/kolla/" + dimensions: "{{ prometheus_elasticsearch_exporter_dimensions }}" #################### # Database @@ -160,6 +170,10 @@ prometheus_openstack_exporter_image: "{{ docker_registry ~ '/' if docker_registr prometheus_openstack_exporter_tag: "{{ prometheus_tag }}" prometheus_openstack_exporter_image_full: "{{ prometheus_openstack_exporter_image }}:{{ prometheus_openstack_exporter_tag }}" +prometheus_elasticsearch_exporter_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/{{ kolla_base_distro }}-{{ prometheus_install_type }}-prometheus-elasticsearch-exporter" +prometheus_elasticsearch_exporter_tag: "{{ prometheus_tag }}" +prometheus_elasticsearch_exporter_image_full: "{{ prometheus_elasticsearch_exporter_image }}:{{ prometheus_elasticsearch_exporter_tag }}" + prometheus_server_dimensions: "{{ default_container_dimensions }}" prometheus_haproxy_exporter_dimensions: "{{ default_container_dimensions }}" prometheus_mysqld_exporter_dimensions: "{{ default_container_dimensions }}" @@ -168,3 +182,4 @@ prometheus_memcached_exporter_dimensions: "{{ default_container_dimensions }}" prometheus_cadvisor_dimensions: "{{ default_container_dimensions }}" prometheus_alertmanager_dimensions: "{{ default_container_dimensions }}" prometheus_openstack_exporter_dimensions: "{{ default_container_dimensions }}" +prometheus_elasticsearch_exporter_dimensions: "{{ default_container_dimensions }}" diff --git a/ansible/roles/prometheus/handlers/main.yml b/ansible/roles/prometheus/handlers/main.yml index a6b7090e74..300927bb2e 100644 --- a/ansible/roles/prometheus/handlers/main.yml +++ b/ansible/roles/prometheus/handlers/main.yml @@ -168,3 +168,24 @@ - config_json.changed | bool or prometheus_openstack_exporter_confs.changed | bool or prometheus_container.changed | bool + +- name: Restart prometheus-elasticsearch-exporter container + vars: + service_name: "prometheus-elasticsearch-exporter" + service: "{{ prometheus_services[service_name] }}" + config_json: "{{ prometheus_config_jsons.results|selectattr('item.key', 'equalto', service_name)|first }}" + prometheus_container: "{{ check_prometheus_containers.results|selectattr('item.key', 'equalto', service_name)|first }}" + become: true + kolla_docker: + action: "recreate_or_restart_container" + common_options: "{{ docker_common_options }}" + name: "{{ service.container_name }}" + image: "{{ service.image }}" + volumes: "{{ service.volumes }}" + dimensions: "{{ service.dimensions }}" + when: + - kolla_action != "config" + - inventory_hostname in groups[service.group] + - service.enabled | bool + - config_json.changed | bool + or prometheus_container.changed | bool diff --git a/ansible/roles/prometheus/tasks/precheck.yml b/ansible/roles/prometheus/tasks/precheck.yml index ef402c8c24..a9290ade1e 100644 --- a/ansible/roles/prometheus/tasks/precheck.yml +++ b/ansible/roles/prometheus/tasks/precheck.yml @@ -10,6 +10,7 @@ - prometheus_cadvisor - prometheus_alertmanager - prometheus_openstack_exporter + - prometheus_elasticsearch_exporter register: container_facts - name: Checking free port for Prometheus server @@ -111,3 +112,17 @@ - enable_prometheus_openstack_exporter | bool with_items: - "{{ prometheus_openstack_exporter_port }}" + +- name: Checking free ports for Prometheus elasticsearch-exporter + wait_for: + host: "{{ hostvars[inventory_hostname]['ansible_' + api_interface]['ipv4']['address'] }}" + port: "{{ item }}" + connect_timeout: 1 + timeout: 1 + state: stopped + when: + - container_facts['prometheus_elasticsearch_exporter'] is not defined + - inventory_hostname in groups['prometheus-elasticsearch-exporter'] + - enable_prometheus_elasticsearch_exporter | bool + with_items: + - "{{ prometheus_elasticsearch_exporter_port }}" diff --git a/ansible/roles/prometheus/templates/prometheus-elasticsearch-exporter.json.j2 b/ansible/roles/prometheus/templates/prometheus-elasticsearch-exporter.json.j2 new file mode 100644 index 0000000000..4aea2129ea --- /dev/null +++ b/ansible/roles/prometheus/templates/prometheus-elasticsearch-exporter.json.j2 @@ -0,0 +1,11 @@ +{ + "command": "/opt/elasticsearch_exporter/elasticsearch_exporter -es.uri http://{{ api_interface_address }}:{{ elasticsearch_port }} -web.listen-address {{ api_interface_address }}:{{ prometheus_elasticsearch_exporter_port }}", + "config_files": [], + "permissions": [ + { + "path": "/var/log/kolla/prometheus", + "owner": "prometheus:kolla", + "recurse": true + } + ] +} diff --git a/ansible/roles/prometheus/templates/prometheus.yml.j2 b/ansible/roles/prometheus/templates/prometheus.yml.j2 index 1d8e3168b7..73cd773ae9 100644 --- a/ansible/roles/prometheus/templates/prometheus.yml.j2 +++ b/ansible/roles/prometheus/templates/prometheus.yml.j2 @@ -86,6 +86,16 @@ scrape_configs: {% endfor %} {% endif %} +{% if enable_prometheus_elasticsearch_exporter | bool %} + - job_name: elasticsearch_exporter + scrape_interval: {{ prometheus_elasticsearch_exporter_interval }} + static_configs: + - targets: +{% for host in groups["prometheus-elasticsearch-exporter"] %} + - '{{ hostvars[host]['ansible_' + hostvars[host]['api_interface']]['ipv4']['address'] }}:{{ hostvars[host]['prometheus_elasticsearch_exporter_port'] }}' +{% endfor %} +{% endif %} + {% if enable_prometheus_alertmanager | bool %} alerting: alertmanagers: diff --git a/ansible/site.yml b/ansible/site.yml index 1ae7dc53de..5814e1b646 100644 --- a/ansible/site.yml +++ b/ansible/site.yml @@ -466,6 +466,7 @@ - prometheus-cadvisor - prometheus-alertmanager - prometheus-openstack-exporter + - prometheus-elasticsearch-exporter - '&enable_prometheus_True' serial: '{{ kolla_serial|default("0") }}' roles: diff --git a/etc/kolla/globals.yml b/etc/kolla/globals.yml index 5686aad338..94a855a45a 100644 --- a/etc/kolla/globals.yml +++ b/etc/kolla/globals.yml @@ -545,3 +545,4 @@ tempest_floating_network_name: #enable_prometheus_alertmanager: "{{ enable_prometheus | bool }}" #enable_prometheus_ceph_mgr_exporter: "{{ enable_prometheus | bool and enable_ceph | bool }}" #enable_prometheus_openstack_exporter: "{{ enable_prometheus | bool }}" +#enable_prometheus_elasticsearch_exporter: "{{ enable_prometheus | bool and enable_elasticsearch | bool }}" diff --git a/releasenotes/notes/add-prometheus-elasticsearch-exporter-4d9b75b5cb8801d1.yaml b/releasenotes/notes/add-prometheus-elasticsearch-exporter-4d9b75b5cb8801d1.yaml new file mode 100644 index 0000000000..e827db1a03 --- /dev/null +++ b/releasenotes/notes/add-prometheus-elasticsearch-exporter-4d9b75b5cb8801d1.yaml @@ -0,0 +1,5 @@ +--- +features: + - | + Deploys and configures the prometheus-elasticsearch-exporter (https://github.com/justwatchcom/elasticsearch_exporter/) + as part of the prometheus monitoring exporters stack. diff --git a/tests/templates/inventory.j2 b/tests/templates/inventory.j2 index 777d7251da..42f7dcad20 100644 --- a/tests/templates/inventory.j2 +++ b/tests/templates/inventory.j2 @@ -661,3 +661,6 @@ storage [prometheus-openstack-exporter:children] monitoring + +[prometheus-elasticsearch-exporter:children] +elasticsearch