9702d4c3c3
Including tasks has a performance penalty when compared with importing tasks. If the include has a condition associated with it, then the overhead of the include may be lower than the overhead of skipping all imported tasks. In the case of the check-containers.yml include, the included file only has a single task, so the overhead of skipping this task will not be greater than the overhead of the task import. It therefore makes sense to switch to use import_tasks there. Partially-Implements: blueprint performance-improvements Change-Id: I65d911670649960708b9f6a4c110d1a7df1ad8f7
218 lines
7.4 KiB
YAML
218 lines
7.4 KiB
YAML
---
|
|
- name: Ensuring config directories exist
|
|
become: true
|
|
file:
|
|
path: "{{ node_config_directory }}/{{ item.key }}"
|
|
state: "directory"
|
|
owner: "{{ config_owner_user }}"
|
|
group: "{{ config_owner_group }}"
|
|
mode: "0770"
|
|
when:
|
|
- inventory_hostname in groups[item.value.group]
|
|
- item.value.enabled | bool
|
|
with_dict: "{{ prometheus_services }}"
|
|
|
|
- include_tasks: copy-certs.yml
|
|
when:
|
|
- kolla_copy_ca_into_containers | bool
|
|
|
|
- name: Copying over config.json files
|
|
become: true
|
|
template:
|
|
src: "{{ item.key }}.json.j2"
|
|
dest: "{{ node_config_directory }}/{{ item.key }}/config.json"
|
|
mode: "0660"
|
|
when:
|
|
- inventory_hostname in groups[item.value.group]
|
|
- item.value.enabled | bool
|
|
with_dict: "{{ prometheus_services }}"
|
|
notify:
|
|
- Restart {{ item.key }} container
|
|
|
|
- name: Find custom prometheus alert rules files
|
|
become: true
|
|
find:
|
|
path: "{{ node_custom_config }}/prometheus/"
|
|
pattern: "*.rules"
|
|
run_once: True
|
|
delegate_to: localhost
|
|
register: prometheus_alert_rules
|
|
when:
|
|
- enable_prometheus_alertmanager | bool
|
|
|
|
- name: Copying over custom prometheus alert rules files
|
|
become: true
|
|
vars:
|
|
service: "{{ prometheus_services['prometheus-server'] }}"
|
|
copy:
|
|
src: "{{ item.path }}"
|
|
dest: "{{ node_config_directory }}/prometheus-server/{{ item.path | basename }}"
|
|
mode: "0660"
|
|
when:
|
|
- inventory_hostname in groups[service.group]
|
|
- service.enabled | bool and enable_prometheus_alertmanager | bool
|
|
- prometheus_alert_rules is defined and prometheus_alert_rules.files | length > 0
|
|
with_items: "{{ prometheus_alert_rules.files }}"
|
|
notify:
|
|
- Restart prometheus-server container
|
|
|
|
- name: Find prometheus common config overrides
|
|
find:
|
|
# NOTE(wszumski): Non-existent paths don't produce a failure
|
|
paths:
|
|
- "{{ node_custom_config }}/prometheus/prometheus.yml.d"
|
|
patterns: "*.yml"
|
|
delegate_to: localhost
|
|
register: prometheus_common_config_overrides_result
|
|
run_once: true
|
|
|
|
- name: Find prometheus host config overrides
|
|
find:
|
|
# NOTE(wszumski): Non-existent paths don't produce a failure
|
|
paths:
|
|
- "{{ node_custom_config }}/prometheus/{{ inventory_hostname }}/prometheus.yml.d"
|
|
patterns: "*.yml"
|
|
delegate_to: localhost
|
|
register: prometheus_host_config_overrides_result
|
|
# NOTE(yoctozepto): this cannot be run_once
|
|
run_once: false
|
|
|
|
- name: Copying over prometheus config file
|
|
become: true
|
|
vars:
|
|
service: "{{ prometheus_services['prometheus-server'] }}"
|
|
common_overrides: "{{ prometheus_common_config_overrides_result.files | map(attribute='path') | list }}"
|
|
host_overrides: "{{ prometheus_host_config_overrides_result.files | map(attribute='path') | list }}"
|
|
merge_yaml:
|
|
sources: "{{ [item] + common_overrides + host_overrides }}"
|
|
dest: "{{ node_config_directory }}/prometheus-server/prometheus.yml"
|
|
mode: "0660"
|
|
extend_lists: true
|
|
when:
|
|
- inventory_hostname in groups[service.group]
|
|
- service.enabled | bool
|
|
with_first_found:
|
|
- "{{ node_custom_config }}/prometheus/{{ inventory_hostname }}/prometheus.yml"
|
|
- "{{ node_custom_config }}/prometheus/prometheus.yml"
|
|
- "{{ role_path }}/templates/prometheus.yml.j2"
|
|
notify:
|
|
- Restart prometheus-server container
|
|
|
|
- name: Copying over prometheus alertmanager config file
|
|
become: true
|
|
vars:
|
|
service: "{{ prometheus_services['prometheus-alertmanager'] }}"
|
|
template:
|
|
src: "{{ item }}"
|
|
dest: "{{ node_config_directory }}/prometheus-alertmanager/prometheus-alertmanager.yml"
|
|
mode: "0660"
|
|
when:
|
|
- inventory_hostname in groups[service.group]
|
|
- service.enabled | bool
|
|
with_first_found:
|
|
- "{{ node_custom_config }}/prometheus/{{ inventory_hostname }}/prometheus-alertmanager.yml"
|
|
- "{{ node_custom_config }}/prometheus/prometheus-alertmanager.yml"
|
|
- "{{ role_path }}/templates/prometheus-alertmanager.yml.j2"
|
|
notify:
|
|
- Restart prometheus-alertmanager container
|
|
|
|
- name: Copying over my.cnf for mysqld_exporter
|
|
become: true
|
|
vars:
|
|
service: "{{ prometheus_services['prometheus-mysqld-exporter'] }}"
|
|
merge_configs:
|
|
sources:
|
|
- "{{ node_custom_config }}/prometheus-mysqld-exporter/{{ inventory_hostname }}/my.cnf"
|
|
- "{{ node_custom_config }}/prometheus-mysqld-exporter/my.cnf"
|
|
- "{{ role_path }}/templates/my.cnf.j2"
|
|
dest: "{{ node_config_directory }}/prometheus-mysqld-exporter/my.cnf"
|
|
mode: "0660"
|
|
when:
|
|
- inventory_hostname in groups[service.group]
|
|
- service.enabled | bool
|
|
notify:
|
|
- Restart prometheus-mysqld-exporter container
|
|
|
|
- name: Copying cloud config file for openstack exporter
|
|
become: true
|
|
vars:
|
|
service: "{{ prometheus_services['prometheus-openstack-exporter'] }}"
|
|
template:
|
|
src: "{{ item }}"
|
|
dest: "{{ node_config_directory }}/prometheus-openstack-exporter/clouds.yml"
|
|
mode: "0660"
|
|
when:
|
|
- inventory_hostname in groups[service.group]
|
|
- service.enabled | bool
|
|
with_first_found:
|
|
- "{{ node_custom_config }}/prometheus-openstack-exporter/{{ inventory_hostname }}/clouds.yml"
|
|
- "{{ node_custom_config }}/prometheus-openstack-exporter/clouds.yml"
|
|
- "{{ role_path }}/templates/clouds.yml.j2"
|
|
notify:
|
|
- Restart prometheus-openstack-exporter container
|
|
|
|
- name: Copying config file for blackbox exporter
|
|
become: true
|
|
vars:
|
|
service: "{{ prometheus_services['prometheus-blackbox-exporter'] }}"
|
|
template:
|
|
src: "{{ item }}"
|
|
dest: "{{ node_config_directory }}/prometheus-blackbox-exporter/prometheus-blackbox-exporter.yml"
|
|
mode: "0660"
|
|
when:
|
|
- inventory_hostname in groups[service.group]
|
|
- service.enabled | bool
|
|
with_first_found:
|
|
- "{{ node_custom_config }}/prometheus/{{ inventory_hostname }}/prometheus-blackbox-exporter.yml"
|
|
- "{{ node_custom_config }}/prometheus/prometheus-blackbox-exporter.yml"
|
|
- "{{ role_path }}/templates/prometheus-blackbox-exporter.yml.j2"
|
|
notify:
|
|
- Restart prometheus-blackbox-exporter container
|
|
|
|
- block:
|
|
- name: Find extra prometheus server config files
|
|
find:
|
|
paths: "{{ node_custom_config }}/prometheus/extras/"
|
|
patterns: "*"
|
|
recurse: true
|
|
delegate_to: localhost
|
|
register: prometheus_config_extras_result
|
|
run_once: true
|
|
|
|
- name: Create subdirectories for extra config files
|
|
become: true
|
|
vars:
|
|
dirs: >-
|
|
{{ prometheus_config_extras_result.files | default([])
|
|
| map(attribute='path') | map('dirname') | unique
|
|
| map('relpath', base) | list }}
|
|
file:
|
|
path: "{{ node_config_directory }}/prometheus-server/{{ item }}"
|
|
state: "directory"
|
|
owner: "{{ config_owner_user }}"
|
|
group: "{{ config_owner_group }}"
|
|
mode: "0770"
|
|
recurse: true
|
|
with_items: "{{ dirs }}"
|
|
|
|
- name: Template extra prometheus server config files
|
|
become: true
|
|
vars:
|
|
relpath: "{{ item | relpath(base) }}"
|
|
template:
|
|
src: "{{ item }}"
|
|
dest: "{{ node_config_directory }}/prometheus-server/{{ relpath }}"
|
|
mode: "0660"
|
|
with_items: "{{ prometheus_config_extras_result.files | default([]) | map(attribute='path') | list }}"
|
|
notify:
|
|
- Restart prometheus-server container
|
|
vars:
|
|
base: "{{ node_custom_config }}/prometheus/"
|
|
service: "{{ prometheus_services['prometheus-server'] }}"
|
|
when:
|
|
- inventory_hostname in groups[service.group]
|
|
- service.enabled | bool
|
|
|
|
- import_tasks: check-containers.yml
|
|
when: kolla_action != "config"
|