mirror of
https://github.com/prometheus-community/ansible
synced 2024-11-30 23:59:11 +00:00
9c415697aa
Signed-off-by: Håvard Pettersson <haavard.pettersson@gmail.com>
117 lines
4.3 KiB
YAML
117 lines
4.3 KiB
YAML
---
|
|
- name: Assert usage of systemd as an init system
|
|
ansible.builtin.assert:
|
|
that: ansible_service_mgr == 'systemd'
|
|
msg: "This role only works with systemd"
|
|
|
|
- name: Install package fact dependencies
|
|
become: true
|
|
ansible.builtin.package:
|
|
name: "{{ _pkg_fact_req }}"
|
|
state: present
|
|
when: (_pkg_fact_req)
|
|
vars:
|
|
_pkg_fact_req: "{% if (ansible_pkg_mgr == 'apt') %}\
|
|
{{ ('python-apt' if ansible_python_version is version('3', '<') else 'python3-apt') }}
|
|
{% else %}\
|
|
{% endif %}"
|
|
|
|
- name: Gather package facts
|
|
ansible.builtin.package_facts:
|
|
when: "not 'packages' in ansible_facts"
|
|
|
|
- name: Naive assertion of proper listen address
|
|
ansible.builtin.assert:
|
|
that:
|
|
- "':' in systemd_exporter_web_listen_address"
|
|
|
|
- name: Assert that TLS config is correct
|
|
when: systemd_exporter_tls_server_config | length > 0
|
|
block:
|
|
- name: Assert that systemd_exporter version supports TLS config
|
|
ansible.builtin.assert:
|
|
that:
|
|
- "systemd_exporter_version is version('0.5.0', '>=')"
|
|
|
|
- name: Assert that TLS key and cert path are set
|
|
ansible.builtin.assert:
|
|
that:
|
|
- "systemd_exporter_tls_server_config.cert_file is defined"
|
|
- "systemd_exporter_tls_server_config.key_file is defined"
|
|
|
|
- name: Check existence of TLS cert file
|
|
ansible.builtin.stat:
|
|
path: "{{ systemd_exporter_tls_server_config.cert_file }}"
|
|
register: __systemd_exporter_cert_file
|
|
|
|
- name: Check existence of TLS key file
|
|
ansible.builtin.stat:
|
|
path: "{{ systemd_exporter_tls_server_config.key_file }}"
|
|
register: __systemd_exporter_key_file
|
|
|
|
- name: Assert that TLS key and cert are present
|
|
ansible.builtin.assert:
|
|
that:
|
|
- "{{ __systemd_exporter_cert_file.stat.exists }}"
|
|
- "{{ __systemd_exporter_key_file.stat.exists }}"
|
|
|
|
- name: Assert that systemd version is >= 235 when enabling ip accounting or measuring restart count
|
|
ansible.builtin.assert:
|
|
that:
|
|
- (ansible_facts.packages.systemd | first).version is version('235', '>=')
|
|
when: systemd_exporter_enable_ip_accounting or systemd_exporter_enable_restart_count
|
|
|
|
- name: Set user and group to root to allow access to /proc/X/fd
|
|
ansible.builtin.set_fact:
|
|
systemd_exporter_system_group: "root"
|
|
systemd_exporter_system_user: "root"
|
|
when: systemd_exporter_enable_file_descriptor_size
|
|
|
|
- name: Check if systemd_exporter is installed
|
|
ansible.builtin.stat:
|
|
path: "{{ systemd_exporter_binary_install_dir }}/systemd_exporter"
|
|
register: __systemd_exporter_is_installed
|
|
check_mode: false
|
|
tags:
|
|
- systemd_exporter_install
|
|
|
|
- name: Gather currently installed systemd_exporter version (if any)
|
|
command: "{{ systemd_exporter_binary_install_dir }}/systemd_exporter --version"
|
|
changed_when: false
|
|
register: __systemd_exporter_current_version_output
|
|
check_mode: false
|
|
when: __systemd_exporter_is_installed.stat.exists
|
|
tags:
|
|
- systemd_exporter_install
|
|
- skip_ansible_lint
|
|
|
|
- name: Discover latest version
|
|
ansible.builtin.set_fact:
|
|
systemd_exporter_version: "{{ (lookup('url', 'https://api.github.com/repos/prometheus-community/systemd_exporter/releases/latest',
|
|
headers=_github_api_headers, split_lines=False) | from_json).get('tag_name') | replace('v', '') }}"
|
|
run_once: true
|
|
until: systemd_exporter_version is version('0.0.0', '>=')
|
|
retries: 10
|
|
when:
|
|
- systemd_exporter_version == "latest"
|
|
- systemd_exporter_binary_local_dir | length == 0
|
|
- not systemd_exporter_skip_install
|
|
|
|
- name: Get systemd exporter binary checksum
|
|
when:
|
|
- systemd_exporter_binary_local_dir | length == 0
|
|
- not systemd_exporter_skip_install
|
|
block:
|
|
- name: Get checksum list from github
|
|
ansible.builtin.set_fact:
|
|
_systemd_exporter_checksums: "{{ lookup('url', systemd_exporter_checksums_url, headers=_github_api_headers, wantlist=True) | list }}"
|
|
run_once: true
|
|
until: _systemd_exporter_checksums is search('linux-' + go_arch + '.tar.gz')
|
|
retries: 10
|
|
|
|
- name: "Get checksum for {{ go_arch }}"
|
|
ansible.builtin.set_fact:
|
|
_systemd_exporter_checksum: "{{ item.split(' ')[0] }}"
|
|
with_items: "{{ _systemd_exporter_checksums }}"
|
|
when:
|
|
- "('linux-' + go_arch + '.tar.gz') in item"
|