Skip to content
Snippets Groups Projects
Commit 074d8b0e authored by Zuul's avatar Zuul Committed by Gerrit Code Review
Browse files

Merge "Enable HAProxy Prometheus metrics endpoint"

parents 53f2c582 140722f7
No related branches found
No related tags found
No related merge requests found
Showing
with 49 additions and 75 deletions
...@@ -620,9 +620,6 @@ storage ...@@ -620,9 +620,6 @@ storage
[prometheus-mysqld-exporter:children] [prometheus-mysqld-exporter:children]
mariadb mariadb
[prometheus-haproxy-exporter:children]
loadbalancer
[prometheus-memcached-exporter:children] [prometheus-memcached-exporter:children]
memcached memcached
......
...@@ -639,9 +639,6 @@ storage ...@@ -639,9 +639,6 @@ storage
[prometheus-mysqld-exporter:children] [prometheus-mysqld-exporter:children]
mariadb mariadb
[prometheus-haproxy-exporter:children]
loadbalancer
[prometheus-memcached-exporter:children] [prometheus-memcached-exporter:children]
memcached memcached
......
--- ---
# TODO(dawudm) We should replace these two tasks with a task to check the port
# is free in precheck.yml in the D release
- name: Stop and remove containers for haproxy exporter containers
become: true
kolla_container:
action: "stop_and_remove_container"
name: "prometheus_haproxy_exporter"
when:
- inventory_hostname in groups['loadbalancer']
- name: Removing config for haproxy exporter
file:
path: "{{ node_config_directory }}/prometheus-haproxy-exporter"
state: "absent"
become: true
when:
- inventory_hostname in groups['loadbalancer']
- import_tasks: deploy.yml - import_tasks: deploy.yml
...@@ -42,6 +42,13 @@ listen stats ...@@ -42,6 +42,13 @@ listen stats
stats realm Haproxy\ Stats stats realm Haproxy\ Stats
stats auth {{ haproxy_user }}:{{ haproxy_password }} stats auth {{ haproxy_user }}:{{ haproxy_password }}
{% if enable_prometheus_haproxy_exporter | bool %}
listen metrics
bind {{ api_interface_address }}:{{ prometheus_haproxy_exporter_port }}
mode http
http-request use-service prometheus-exporter if { path /metrics }
{% endif %}
frontend status frontend status
bind {{ api_interface_address }}:{{ haproxy_monitor_port }} bind {{ api_interface_address }}:{{ haproxy_monitor_port }}
{% if api_interface_address != kolla_internal_vip_address %} {% if api_interface_address != kolla_internal_vip_address %}
......
...@@ -37,13 +37,6 @@ prometheus_services: ...@@ -37,13 +37,6 @@ prometheus_services:
image: "{{ prometheus_mysqld_exporter_image_full }}" image: "{{ prometheus_mysqld_exporter_image_full }}"
volumes: "{{ prometheus_mysqld_exporter_default_volumes + prometheus_mysqld_exporter_extra_volumes }}" volumes: "{{ prometheus_mysqld_exporter_default_volumes + prometheus_mysqld_exporter_extra_volumes }}"
dimensions: "{{ prometheus_mysqld_exporter_dimensions }}" dimensions: "{{ prometheus_mysqld_exporter_dimensions }}"
prometheus-haproxy-exporter:
container_name: prometheus_haproxy_exporter
group: prometheus-haproxy-exporter
enabled: "{{ enable_prometheus_haproxy_exporter | bool }}"
image: "{{ prometheus_haproxy_exporter_image_full }}"
volumes: "{{ prometheus_haproxy_exporter_default_volumes + prometheus_haproxy_exporter_extra_volumes }}"
dimensions: "{{ prometheus_haproxy_exporter_dimensions }}"
prometheus-memcached-exporter: prometheus-memcached-exporter:
container_name: prometheus_memcached_exporter container_name: prometheus_memcached_exporter
group: prometheus-memcached-exporter group: prometheus-memcached-exporter
...@@ -197,10 +190,6 @@ prometheus_server_image: "{{ docker_registry ~ '/' if docker_registry else '' }} ...@@ -197,10 +190,6 @@ prometheus_server_image: "{{ docker_registry ~ '/' if docker_registry else '' }}
prometheus_server_tag: "{{ prometheus_tag }}" prometheus_server_tag: "{{ prometheus_tag }}"
prometheus_server_image_full: "{{ prometheus_server_image }}:{{ prometheus_server_tag }}" prometheus_server_image_full: "{{ prometheus_server_image }}:{{ prometheus_server_tag }}"
prometheus_haproxy_exporter_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/prometheus-haproxy-exporter"
prometheus_haproxy_exporter_tag: "{{ prometheus_tag }}"
prometheus_haproxy_exporter_image_full: "{{ prometheus_haproxy_exporter_image }}:{{ prometheus_haproxy_exporter_tag }}"
prometheus_mysqld_exporter_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/prometheus-mysqld-exporter" prometheus_mysqld_exporter_image: "{{ docker_registry ~ '/' if docker_registry else '' }}{{ docker_namespace }}/prometheus-mysqld-exporter"
prometheus_mysqld_exporter_tag: "{{ prometheus_tag }}" prometheus_mysqld_exporter_tag: "{{ prometheus_tag }}"
prometheus_mysqld_exporter_image_full: "{{ prometheus_mysqld_exporter_image }}:{{ prometheus_mysqld_exporter_tag }}" prometheus_mysqld_exporter_image_full: "{{ prometheus_mysqld_exporter_image }}:{{ prometheus_mysqld_exporter_tag }}"
...@@ -243,7 +232,6 @@ prometheus_msteams_tag: "{{ prometheus_tag }}" ...@@ -243,7 +232,6 @@ prometheus_msteams_tag: "{{ prometheus_tag }}"
prometheus_msteams_image_full: "{{ prometheus_msteams_image }}:{{ prometheus_msteams_tag }}" prometheus_msteams_image_full: "{{ prometheus_msteams_image }}:{{ prometheus_msteams_tag }}"
prometheus_server_dimensions: "{{ default_container_dimensions }}" prometheus_server_dimensions: "{{ default_container_dimensions }}"
prometheus_haproxy_exporter_dimensions: "{{ default_container_dimensions }}"
prometheus_mysqld_exporter_dimensions: "{{ default_container_dimensions }}" prometheus_mysqld_exporter_dimensions: "{{ default_container_dimensions }}"
prometheus_node_exporter_dimensions: "{{ default_container_dimensions }}" prometheus_node_exporter_dimensions: "{{ default_container_dimensions }}"
prometheus_memcached_exporter_dimensions: "{{ default_container_dimensions }}" prometheus_memcached_exporter_dimensions: "{{ default_container_dimensions }}"
...@@ -261,12 +249,6 @@ prometheus_server_default_volumes: ...@@ -261,12 +249,6 @@ prometheus_server_default_volumes:
- "{{ '/etc/timezone:/etc/timezone:ro' if ansible_facts.os_family == 'Debian' else '' }}" - "{{ '/etc/timezone:/etc/timezone:ro' if ansible_facts.os_family == 'Debian' else '' }}"
- "prometheus_v2:/var/lib/prometheus" - "prometheus_v2:/var/lib/prometheus"
- "kolla_logs:/var/log/kolla/" - "kolla_logs:/var/log/kolla/"
prometheus_haproxy_exporter_default_volumes:
- "{{ node_config_directory }}/prometheus-haproxy-exporter/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro"
- "{{ '/etc/timezone:/etc/timezone:ro' if ansible_facts.os_family == 'Debian' else '' }}"
- "kolla_logs:/var/log/kolla/"
- "haproxy_socket:/var/lib/kolla/haproxy"
prometheus_mysqld_exporter_default_volumes: prometheus_mysqld_exporter_default_volumes:
- "{{ node_config_directory }}/prometheus-mysqld-exporter/:{{ container_config_directory }}/:ro" - "{{ node_config_directory }}/prometheus-mysqld-exporter/:{{ container_config_directory }}/:ro"
- "/etc/localtime:/etc/localtime:ro" - "/etc/localtime:/etc/localtime:ro"
...@@ -327,7 +309,6 @@ prometheus_msteams_default_volumes: ...@@ -327,7 +309,6 @@ prometheus_msteams_default_volumes:
prometheus_extra_volumes: "{{ default_extra_volumes }}" prometheus_extra_volumes: "{{ default_extra_volumes }}"
prometheus_server_extra_volumes: "{{ prometheus_extra_volumes }}" prometheus_server_extra_volumes: "{{ prometheus_extra_volumes }}"
prometheus_haproxy_exporter_extra_volumes: "{{ prometheus_extra_volumes }}"
prometheus_mysqld_exporter_extra_volumes: "{{ prometheus_extra_volumes }}" prometheus_mysqld_exporter_extra_volumes: "{{ prometheus_extra_volumes }}"
prometheus_node_exporter_extra_volumes: "{{ prometheus_extra_volumes }}" prometheus_node_exporter_extra_volumes: "{{ prometheus_extra_volumes }}"
prometheus_memcached_exporter_extra_volumes: "{{ prometheus_extra_volumes }}" prometheus_memcached_exporter_extra_volumes: "{{ prometheus_extra_volumes }}"
...@@ -356,7 +337,6 @@ prometheus_server_command: >- ...@@ -356,7 +337,6 @@ prometheus_server_command: >-
prometheus_blackbox_exporter_cmdline_extras: "" prometheus_blackbox_exporter_cmdline_extras: ""
prometheus_cadvisor_cmdline_extras: "--docker_only --store_container_labels=false --disable_metrics=percpu,referenced_memory,cpu_topology,resctrl,udp,advtcp,sched,hugetlb,memory_numa,tcp,process --housekeeping_interval={{ prometheus_scrape_interval }}" prometheus_cadvisor_cmdline_extras: "--docker_only --store_container_labels=false --disable_metrics=percpu,referenced_memory,cpu_topology,resctrl,udp,advtcp,sched,hugetlb,memory_numa,tcp,process --housekeeping_interval={{ prometheus_scrape_interval }}"
prometheus_elasticsearch_exporter_cmdline_extras: "" prometheus_elasticsearch_exporter_cmdline_extras: ""
prometheus_haproxy_exporter_cmdline_extras: ""
prometheus_memcached_exporter_cmdline_extras: "" prometheus_memcached_exporter_cmdline_extras: ""
prometheus_mysqld_exporter_cmdline_extras: "" prometheus_mysqld_exporter_cmdline_extras: ""
prometheus_node_exporter_cmdline_extras: "" prometheus_node_exporter_cmdline_extras: ""
......
...@@ -45,21 +45,6 @@ ...@@ -45,21 +45,6 @@
when: when:
- kolla_action != "config" - kolla_action != "config"
- name: Restart prometheus-haproxy-exporter container
vars:
service_name: "prometheus-haproxy-exporter"
service: "{{ prometheus_services[service_name] }}"
become: true
kolla_container:
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"
- name: Restart prometheus-memcached-exporter container - name: Restart prometheus-memcached-exporter container
vars: vars:
service_name: "prometheus-memcached-exporter" service_name: "prometheus-memcached-exporter"
......
...@@ -12,7 +12,6 @@ ...@@ -12,7 +12,6 @@
name: name:
- prometheus_server - prometheus_server
- prometheus_node_exporter - prometheus_node_exporter
- prometheus_haproxy_exporter
- prometheus_memcached_exporter - prometheus_memcached_exporter
- prometheus_mysqld_exporter - prometheus_mysqld_exporter
- prometheus_cadvisor - prometheus_cadvisor
...@@ -83,18 +82,6 @@ ...@@ -83,18 +82,6 @@
- inventory_hostname in groups['prometheus-mysqld-exporter'] - inventory_hostname in groups['prometheus-mysqld-exporter']
- enable_prometheus_mysqld_exporter | bool - enable_prometheus_mysqld_exporter | bool
- name: Checking free port for Prometheus haproxy_exporter
wait_for:
host: "{{ 'api' | kolla_address }}"
port: "{{ prometheus_haproxy_exporter_port }}"
connect_timeout: 1
timeout: 1
state: stopped
when:
- container_facts['prometheus_haproxy_exporter'] is not defined
- inventory_hostname in groups['prometheus-haproxy-exporter']
- enable_prometheus_haproxy_exporter | bool
- name: Checking free port for Prometheus memcached_exporter - name: Checking free port for Prometheus memcached_exporter
wait_for: wait_for:
host: "{{ 'api' | kolla_address }}" host: "{{ 'api' | kolla_address }}"
......
{
"command": "/opt/haproxy_exporter/haproxy_exporter --haproxy.scrape-uri unix:/var/lib/kolla/haproxy/haproxy.sock --web.listen-address {{ api_interface_address | put_address_in_context('url') }}:{{ prometheus_haproxy_exporter_port }}{% if prometheus_haproxy_exporter_cmdline_extras %} {{ prometheus_haproxy_exporter_cmdline_extras }}{% endif %}",
"config_files": [],
"permissions": [
{
"path": "/var/log/kolla/prometheus",
"owner": "prometheus:kolla",
"recurse": true
}
]
}
...@@ -60,9 +60,9 @@ scrape_configs: ...@@ -60,9 +60,9 @@ scrape_configs:
{% if enable_prometheus_haproxy_exporter | bool %} {% if enable_prometheus_haproxy_exporter | bool %}
- job_name: haproxy - job_name: haproxy
static_configs: static_configs:
{% for host in groups['prometheus-haproxy-exporter'] %} {% for host in groups['loadbalancer'] %}
- targets: - targets:
- '{{ 'api' | kolla_address(host) | put_address_in_context('url') }}:{{ hostvars[host]['prometheus_haproxy_exporter_port'] }}' - '{{ 'api' | kolla_address(host) | put_address_in_context('url') }}:{{ prometheus_haproxy_exporter_port }}'
{% if hostvars[host].prometheus_instance_label | default(false, true) %} {% if hostvars[host].prometheus_instance_label | default(false, true) %}
labels: labels:
instance: "{{ hostvars[host].prometheus_instance_label }}" instance: "{{ hostvars[host].prometheus_instance_label }}"
......
...@@ -452,7 +452,6 @@ ...@@ -452,7 +452,6 @@
- prometheus - prometheus
- prometheus-node-exporter - prometheus-node-exporter
- prometheus-mysqld-exporter - prometheus-mysqld-exporter
- prometheus-haproxy-exporter
- prometheus-memcached-exporter - prometheus-memcached-exporter
- prometheus-cadvisor - prometheus-cadvisor
- prometheus-alertmanager - prometheus-alertmanager
......
...@@ -796,7 +796,6 @@ workaround_ansible_issue_8743: yes ...@@ -796,7 +796,6 @@ workaround_ansible_issue_8743: yes
# Extra parameters passed to Prometheus exporters. # Extra parameters passed to Prometheus exporters.
#prometheus_blackbox_exporter_cmdline_extras: #prometheus_blackbox_exporter_cmdline_extras:
#prometheus_elasticsearch_exporter_cmdline_extras: #prometheus_elasticsearch_exporter_cmdline_extras:
#prometheus_haproxy_exporter_cmdline_extras:
#prometheus_memcached_exporter_cmdline_extras: #prometheus_memcached_exporter_cmdline_extras:
#prometheus_mysqld_exporter_cmdline_extras: #prometheus_mysqld_exporter_cmdline_extras:
#prometheus_node_exporter_cmdline_extras: #prometheus_node_exporter_cmdline_extras:
......
---
features:
- |
Removed configuration and deployment of ``prometheus-haproxy-exporter`` as
its repository is now archived. We now use the native support for
Prometheus which is now built into HAProxy. For consistency this is exposed
on the ``prometheus_haproxy_exporter_port`` port.
``prometheus-haproxy-exporter`` containers and config are automatically
removed.
upgrade:
- |
Due to the change from using the ``prometheus-haproxy-exporter`` to using
the native support for Prometheus which is now built into HAProxy, metric
names may have been replaced and/or removed, and in some cases the metric
names may have remained the same but the labels may have changed. Alerts
and dashboards may also need to be updated to use the new metrics. Please
review any configuration that references the old metrics as this is not a
backwards compatible change.
...@@ -261,9 +261,9 @@ As with all optional services in Kolla Ansible, Prometheus deployment should be ...@@ -261,9 +261,9 @@ As with all optional services in Kolla Ansible, Prometheus deployment should be
controlled by Kolla Ansible variables. A high level enable_prometheus variable controlled by Kolla Ansible variables. A high level enable_prometheus variable
should control whether Prometheus is used at all. Additionally, additional should control whether Prometheus is used at all. Additionally, additional
variables can be used to control individual exporters. For example, variables can be used to control individual exporters. For example,
enable_prometheus_haproxy could be used to enable/disable the HAProxy exporter enable_prometheus_haproxy_exporter could be used to enable/disable the HAProxy
to Prometheus. By default Prometheus should be enabled and exporters should be exporter to Prometheus. By default Prometheus should be enabled and exporters
enabled if both Prometheus and the associated service are enabled. should be enabled if both Prometheus and the associated service are enabled.
Limitations Limitations
----------- -----------
......
...@@ -681,9 +681,6 @@ storage ...@@ -681,9 +681,6 @@ storage
[prometheus-mysqld-exporter:children] [prometheus-mysqld-exporter:children]
mariadb mariadb
[prometheus-haproxy-exporter:children]
loadbalancer
[prometheus-memcached-exporter:children] [prometheus-memcached-exporter:children]
memcached memcached
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment