Compare commits
60 Commits
Author | SHA1 | Date | |
---|---|---|---|
e642e2f97a
|
|||
31a0aa4ce4
|
|||
5afbff72ac
|
|||
17c97f7cc4
|
|||
dc584ef7a6
|
|||
49903d0035
|
|||
92777a6e15
|
|||
e0b935a2c7
|
|||
f75ffdcd9c
|
|||
8a7f88ba0d
|
|||
446e226af0
|
|||
2d297d7c93
|
|||
e78bd87505
|
|||
b63b966659
|
|||
ddb6ab9d05
|
|||
838110062e
|
|||
f4325bad78
|
|||
37cf8c7c69
|
|||
d24ec49b36
|
|||
9eca35af09
|
|||
1ebb852608
|
|||
d3c92fc0e4
|
|||
0fd6ee4ba6
|
|||
74282776b1
|
|||
3b20652c51
|
|||
c5df5a47b8
|
|||
74206fbb87
|
|||
21ea611513
|
|||
8ce351121a
|
|||
d758c1abcb
|
|||
5d70700332
|
|||
60bb90126b
|
|||
ac26c4053b
|
|||
a8e931177f
|
|||
9afda06a6c
|
|||
2af7c24b5a
|
|||
c9bcb1c1d2
|
|||
7b7a124daa
|
|||
0f504175a7
|
|||
623fafde77
|
|||
d6a395034d
|
|||
81bed762cc
|
|||
4d167d901d
|
|||
815784757e
|
|||
6b447b1478
|
|||
2da3caab8e
|
|||
8ffc272ff6
|
|||
af80d1eed8
|
|||
533fbd1630
|
|||
cef1d292b7
|
|||
838f168e58
|
|||
492e134f4a
|
|||
2183832a3c
|
|||
02ad9e471d
|
|||
fb0915841d
|
|||
d8a3b0ab75
|
|||
adfba06008
|
|||
190f1480d2
|
|||
37a6e040fd
|
|||
fe29c97c53
|
@ -11,10 +11,13 @@ metrics or alerting.
|
||||
alertmanager for receiving alerts from prometheus and routing them
|
||||
to the correct configured receivers.
|
||||
|
||||
- [`cadvisor`](roles/cadvisor/README.md): Run and configure cAdvisor, googles'
|
||||
container performance and resource usage collection and aggregation daemon.
|
||||
|
||||
- [`grafana`](roles/grafana/README.md): a popular visualization and
|
||||
dashboard creation tool able to use various datasources.
|
||||
|
||||
- [`matrix-alertmanager`](roles/matrix-alertmanager/README.md): An alert-
|
||||
- [`matrix_alertmanager`](roles/matrix_alertmanager/README.md): An alert-
|
||||
manager receiver which posts alerts to a configured matrix channel
|
||||
using alertmanagers' webhooks.
|
||||
|
||||
|
@ -1,12 +1,12 @@
|
||||
namespace: finallycoffee
|
||||
name: observability
|
||||
version: 0.1.1
|
||||
version: "0.1.6"
|
||||
readme: README.md
|
||||
authors:
|
||||
- transcaffeine <transcaffeine@finally.coffee>
|
||||
description: Various ansible roles useful for automating infrastructure
|
||||
dependencies:
|
||||
"community.docker": "^3.0.0"
|
||||
"community.docker": "^4.4.0"
|
||||
license_file: LICENSE.md
|
||||
build_ignore:
|
||||
- '*.tar.gz'
|
||||
@ -18,3 +18,4 @@ tags:
|
||||
- prometheus
|
||||
- victoriametrics
|
||||
- grafana
|
||||
- alertmanager
|
||||
|
8
roles/alertmanager/defaults/main/config.yml
Normal file
8
roles/alertmanager/defaults/main/config.yml
Normal file
@ -0,0 +1,8 @@
|
||||
---
|
||||
alertmanager_config_global: {}
|
||||
alertmanager_config_route: {}
|
||||
alertmanager_config_receivers: []
|
||||
alertmanager_config:
|
||||
global: "{{ alertmanager_config_global }}"
|
||||
route: "{{ alertmanager_config_route }}"
|
||||
receivers: "{{ alertmanager_config_receivers }}"
|
@ -1,11 +1,4 @@
|
||||
---
|
||||
alertmanager_user: alertmanager
|
||||
alertmanager_version: 0.27.0
|
||||
alertmanager_base_path: /opt/alertmanager
|
||||
alertmanager_config_path: "{{ alertmanager_base_path }}/config"
|
||||
alertmanager_config_file: "{{ alertmanager_config_path }}/alertmanager.yml"
|
||||
alertmanager_data_path: "{{ alertmanager_base_path }}/data"
|
||||
|
||||
alertmanager_container_name: alertmanager
|
||||
alertmanager_container_image_name: alertmanager
|
||||
alertmanager_container_image_namespace: prometheus/
|
||||
@ -22,7 +15,7 @@ alertmanager_container_image_reference: >-
|
||||
alertmanager_container_image_repository + ':'
|
||||
+ (alertmanager_container_image_tag | default('v' + alertmanager_version))
|
||||
}}
|
||||
|
||||
alertmanager_container_image_source: pull
|
||||
alertmanager_container_image_force_pull: "{{ alertmanager_container_image_tag is defined }}"
|
||||
|
||||
alertmanager_container_default_volumes:
|
||||
@ -32,8 +25,5 @@ alertmanager_container_volumes: >-
|
||||
{{ alertmanager_container_default_volumes
|
||||
+ alertmanager_container_extra_volumes | default([]) }}
|
||||
alertmanager_container_restart_policy: "unless-stopped"
|
||||
|
||||
alertmanager_config:
|
||||
global: {}
|
||||
route: {}
|
||||
receivers: []
|
||||
alertmanager_container_state: >-2
|
||||
{{ (alertmanager_state == 'present') | ternary('started', 'absent') }}
|
10
roles/alertmanager/defaults/main/main.yml
Normal file
10
roles/alertmanager/defaults/main/main.yml
Normal file
@ -0,0 +1,10 @@
|
||||
---
|
||||
alertmanager_user: alertmanager
|
||||
alertmanager_version: "0.28.0"
|
||||
alertmanager_state: present
|
||||
alertmanager_deployment_method: docker
|
||||
alertmanager_base_path: /opt/alertmanager
|
||||
alertmanager_config_path: "{{ alertmanager_base_path }}/config"
|
||||
alertmanager_config_file: "{{ alertmanager_config_path }}/alertmanager.yml"
|
||||
alertmanager_data_path: "{{ alertmanager_base_path }}/data"
|
||||
|
@ -1,8 +1,8 @@
|
||||
---
|
||||
|
||||
- name: Ensure alertmanager is restarted
|
||||
community.docker.docker_container:
|
||||
name: "{{ alertmanager_container_name }}"
|
||||
state: started
|
||||
state: "{{ alertmanager_container_state }}"
|
||||
restart: true
|
||||
listen: restart-alertmanager
|
||||
when: alertmanager_deployment_method == 'docker'
|
||||
|
10
roles/alertmanager/meta/main.yml
Normal file
10
roles/alertmanager/meta/main.yml
Normal file
@ -0,0 +1,10 @@
|
||||
---
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: alertmanager
|
||||
description: Deploy and configure prometheus alertmanager
|
||||
galaxy_tags:
|
||||
- prometheus
|
||||
- alertmanager
|
||||
- observability
|
21
roles/alertmanager/tasks/deploy-docker.yml
Normal file
21
roles/alertmanager/tasks/deploy-docker.yml
Normal file
@ -0,0 +1,21 @@
|
||||
---
|
||||
- name: Ensure container image is {{ alertmanager_state }} on host
|
||||
community.docker.docker_image:
|
||||
name: "{{ alertmanager_container_image_reference }}"
|
||||
state: "{{ alertmanager_state }}"
|
||||
source: "{{ alertmanager_container_image_source }}"
|
||||
force_source: "{{ alertmanager_container_image_force_pull | bool }}"
|
||||
|
||||
- name: Ensure container '{{ alertmanager_container_name }}' is {{ alertmanager_container_state }}
|
||||
community.docker.docker_container:
|
||||
name: "{{ alertmanager_container_name }}"
|
||||
image: "{{ alertmanager_container_image_reference }}"
|
||||
env: "{{ alertmanager_container_env | default(omit) }}"
|
||||
user: "{{ alertmanager_user_info.uid | default(alertmanager_user) }}"
|
||||
ports: "{{ alertmanager_container_ports | default(omit) }}"
|
||||
volumes: "{{ alertmanager_container_volumes | default(omit) }}"
|
||||
networks: "{{ alertmanager_container_networks | default(omit) }}"
|
||||
purge_networks: "{{ alertmanager_container_purge_networks | default(omit) }}"
|
||||
etc_hosts: "{{ alertmanager_container_etc_hosts | default(omit) }}"
|
||||
restart_policy: "{{ alertmanager_container_restart_policy }}"
|
||||
state: "{{ alertmanager_container_state }}"
|
@ -1,16 +1,29 @@
|
||||
---
|
||||
- name: Ensure state is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Invalid state '{{ alertmanager_state }}'! Valid
|
||||
states are {{ alertmanager_states | join(', ') }}.
|
||||
when: alertmanager_state not in alertmanager_states
|
||||
|
||||
- name: Ensure alertmanager user '{{ alertmanager_user }}' exists
|
||||
- name: Ensure deployment method is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Invalid deployment method {{ alertmanager_deployment_method }}!
|
||||
Supported deployment methods are {{ alertmanager_deployment_methods | join(', ') }}.
|
||||
when: alertmanager_deployment_method not in alertmanager_deployment_methods
|
||||
|
||||
- name: Ensure alertmanager user '{{ alertmanager_user }}' is {{ alertmanager_state }}
|
||||
ansible.builtin.user:
|
||||
name: "{{ alertmanager_user }}"
|
||||
state: present
|
||||
state: "{{ alertmanager_state }}"
|
||||
system: true
|
||||
register: alertmanager_user_info
|
||||
|
||||
- name: Ensure mounts are created
|
||||
- name: Ensure mounts are {{ alertmanager_state }}
|
||||
ansible.builtin.file:
|
||||
dest: "{{ item.path }}"
|
||||
state: directory
|
||||
state: "{{ (alertmanager_state == 'present') | ternary('directory', 'absent') }}"
|
||||
owner: "{{ item.owner | default(alertmanager_user_info.uid | default(alertmanager_user)) }}"
|
||||
group: "{{ item.owner | default(alertmanager_user_info.group | default(alertmanager_user)) }}"
|
||||
mode: "{{ item.mode | default('0755') }}"
|
||||
@ -24,28 +37,12 @@
|
||||
dest: "{{ alertmanager_config_file }}"
|
||||
content: "{{ alertmanager_config | to_nice_yaml }}"
|
||||
owner: "{{ alertmanager_user_info.uid | default(alertmanager_user) }}"
|
||||
owner: "{{ alertmanager_user_info.uid | default(alertmanager_user) }}"
|
||||
group: "{{ alertmanager_user_info.group | default(alertmanager_user) }}"
|
||||
mode: "0640"
|
||||
when: alertmanager_state == 'present'
|
||||
notify:
|
||||
- restart-alertmanager
|
||||
|
||||
- name: Ensure container image is present on host
|
||||
community.docker.docker_image:
|
||||
name: "{{ alertmanager_container_image_reference }}"
|
||||
state: present
|
||||
source: pull
|
||||
force_source: "{{ alertmanager_container_image_force_pull | bool }}"
|
||||
|
||||
- name: Ensure container '{{ alertmanager_container_name }}' is running
|
||||
community.docker.docker_container:
|
||||
name: "{{ alertmanager_container_name }}"
|
||||
image: "{{ alertmanager_container_image_reference }}"
|
||||
env: "{{ alertmanager_container_env | default(omit) }}"
|
||||
user: "{{ alertmanager_user_info.uid | default(alertmanager_user) }}"
|
||||
ports: "{{ alertmanager_container_ports | default(omit) }}"
|
||||
volumes: "{{ alertmanager_container_volumes | default(omit) }}"
|
||||
networks: "{{ alertmanager_container_networks | default(omit) }}"
|
||||
purge_networks: "{{ alertmanager_container_purge_networks | default(omit) }}"
|
||||
etc_hosts: "{{ alertmanager_container_etc_hosts | default(omit) }}"
|
||||
restart_policy: "{{ alertmanager_container_restart_policy }}"
|
||||
state: started
|
||||
- name: Deploy alertmanager using {{ alertmanager_deployment_method }}
|
||||
ansible.builtin.include_tasks:
|
||||
file: "deploy-{{ alertmanager_deployment_method }}.yml"
|
||||
|
6
roles/alertmanager/vars/main.yml
Normal file
6
roles/alertmanager/vars/main.yml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
alertmanager_states:
|
||||
- present
|
||||
- absent
|
||||
alertmanager_deployment_methods:
|
||||
- docker
|
@ -1,52 +0,0 @@
|
||||
---
|
||||
cadvisor_version: 0.49.1
|
||||
|
||||
cadvisor_container_name: cadvisor
|
||||
cadvisor_container_image_name: gcr.io/cadvisor/cadvisor
|
||||
cadvisor_container_image_tag: ~
|
||||
cadvisor_container_image_ref: >-
|
||||
{{ cadvisor_container_image_name }}:{{ cadvisor_container_image_tag | default('v' + cadvisor_version, True) }}
|
||||
cadvisor_container_volumes: >-
|
||||
{{ cadvisor_container_base_volumes + cadvisor_container_extra_volumes | default([], True) }}
|
||||
cadvisor_container_extra_volumes: ~
|
||||
cadvisor_container_env: ~
|
||||
cadvisor_container_labels: "{{ cadvisor_container_base_labels | combine(cadvisor_container_extra_labels) }}"
|
||||
cadvisor_container_extra_labels: {}
|
||||
cadvisor_container_ports: ~
|
||||
cadvisor_container_networks: ~
|
||||
cadvisor_container_etc_hosts: ~
|
||||
cadvisor_container_devices: [ "/dev/kmsg:/dev/kmsg:rwm" ]
|
||||
cadvisor_container_privileged: yes
|
||||
cadvisor_container_pid_mode: "host"
|
||||
cadvisor_container_userns_mode: "host"
|
||||
cadvisor_container_capabilities: ~
|
||||
cadvisor_container_restart_policy: unless-stopped
|
||||
cadvisor_container_command: >-2
|
||||
{{ ["--docker_only=false"]
|
||||
+ (["--disable_metrics=" + cadvisor_disabled_metrics | join( ',' )]
|
||||
if cadvisor_disabled_metrics | default(false, True) else [])
|
||||
+ (["--enable_metrics=" + cadvisor_force_enable_metrics | join( ',' )]
|
||||
if cadvisor_force_enable_metrics | default(false, True) else [])
|
||||
}}
|
||||
cadvisor_container_base_labels:
|
||||
version: "{{ cadvisor_version }}"
|
||||
cadvisor_container_base_volumes:
|
||||
- "/:/rootfs:ro"
|
||||
- "/var/run:/var/run:ro"
|
||||
- "/sys:/sys:ro"
|
||||
- "/var/lib/docker/:/var/lib/docker:ro"
|
||||
- "/dev/disk/:/dev/disk:ro"
|
||||
|
||||
cadvisor_disabled_metrics:
|
||||
- advtcp
|
||||
- cpu_topology
|
||||
- cpuset
|
||||
- hugetlb
|
||||
- memory_numa
|
||||
- process
|
||||
- referenced_memory
|
||||
- resctrl
|
||||
- sched
|
||||
- tcp
|
||||
- udp
|
||||
cadvisor_force_enable_metrics: []
|
56
roles/cadvisor/defaults/main/container.yml
Normal file
56
roles/cadvisor/defaults/main/container.yml
Normal file
@ -0,0 +1,56 @@
|
||||
---
|
||||
cadvisor_container_image_registry: gcr.io
|
||||
cadvisor_container_image_namespace: cadvisor
|
||||
cadvisor_container_image_name: cadvisor
|
||||
cadvisor_container_image: >-2
|
||||
{{
|
||||
[
|
||||
cadvisor_container_image_registry,
|
||||
cadvisor_container_image_namespace,
|
||||
cadvisor_container_image_name,
|
||||
] | flatten | join('/')
|
||||
}}
|
||||
cadvisor_container_image_tag: ~
|
||||
cadvisor_container_image_ref: >-2
|
||||
{{ cadvisor_container_image }}:{{ cadvisor_container_image_tag | default('v' + cadvisor_version, true) }}
|
||||
cadvisor_container_image_source: pull
|
||||
cadvisor_container_image_force_source: >-2
|
||||
{{ cadvisor_container_image_tag | default(false, true) | bool }}
|
||||
|
||||
cadvisor_container_state: >-2
|
||||
{{ (cadvisor_state == 'present') | ternary('started', 'absent') }}
|
||||
|
||||
cadvisor_container_name: cadvisor
|
||||
cadvisor_container_volumes: >-2
|
||||
{{ cadvisor_container_base_volumes + cadvisor_container_extra_volumes | default([], true) }}
|
||||
cadvisor_container_extra_volumes: ~
|
||||
cadvisor_container_env: ~
|
||||
cadvisor_container_labels: >-2
|
||||
{{ cadvisor_container_base_labels | combine(cadvisor_container_extra_labels) }}
|
||||
cadvisor_container_extra_labels: {}
|
||||
cadvisor_container_ports: ~
|
||||
cadvisor_container_networks: ~
|
||||
cadvisor_container_etc_hosts: ~
|
||||
cadvisor_container_devices:
|
||||
- "/dev/kmsg:/dev/kmsg:rwm"
|
||||
cadvisor_container_privileged: true
|
||||
cadvisor_container_pid_mode: "host"
|
||||
cadvisor_container_userns_mode: "host"
|
||||
cadvisor_container_capabilities: ~
|
||||
cadvisor_container_restart_policy: "unless-stopped"
|
||||
cadvisor_container_command: >-2
|
||||
{{ ["--docker_only=false"]
|
||||
+ (["--disable_metrics=" + cadvisor_disabled_metrics | join( ',' )]
|
||||
if cadvisor_disabled_metrics | default(false, true) else [])
|
||||
+ (["--enable_metrics=" + cadvisor_force_enable_metrics | join( ',' )]
|
||||
if cadvisor_force_enable_metrics | default(false, true) else [])
|
||||
}}
|
||||
cadvisor_container_base_labels:
|
||||
version: "{{ cadvisor_version }}"
|
||||
cadvisor_container_base_volumes:
|
||||
- "/:/rootfs:ro"
|
||||
- "/var/run:/var/run:ro"
|
||||
- "/sys:/sys:ro"
|
||||
- "/var/lib/docker/:/var/lib/docker:ro"
|
||||
- "/dev/disk/:/dev/disk:ro"
|
||||
|
18
roles/cadvisor/defaults/main/main.yml
Normal file
18
roles/cadvisor/defaults/main/main.yml
Normal file
@ -0,0 +1,18 @@
|
||||
---
|
||||
cadvisor_version: "0.51.0"
|
||||
cadvisor_state: present
|
||||
cadvisor_deployment_method: docker
|
||||
|
||||
cadvisor_disabled_metrics:
|
||||
- advtcp
|
||||
- cpu_topology
|
||||
- cpuset
|
||||
- hugetlb
|
||||
- memory_numa
|
||||
- process
|
||||
- referenced_memory
|
||||
- resctrl
|
||||
- sched
|
||||
- tcp
|
||||
- udp
|
||||
cadvisor_force_enable_metrics: []
|
11
roles/cadvisor/meta/main.yml
Normal file
11
roles/cadvisor/meta/main.yml
Normal file
@ -0,0 +1,11 @@
|
||||
---
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: cadvisor
|
||||
description: Deploy cadvisor (Container Advisor), a container performance and resource usage aggregation daemon
|
||||
galaxy_tags:
|
||||
- cadvisor
|
||||
- observability
|
||||
- container
|
||||
- docker
|
25
roles/cadvisor/tasks/deploy-docker.yml
Normal file
25
roles/cadvisor/tasks/deploy-docker.yml
Normal file
@ -0,0 +1,25 @@
|
||||
---
|
||||
- name: Ensure cadvisor container image '{{ cadvisor_container_image_ref }}' is {{ cadvisor_state }}
|
||||
community.docker.docker_image:
|
||||
name: "{{ cadvisor_container_image_ref }}"
|
||||
state: "{{ cadvisor_state }}"
|
||||
source: "{{ cadvisor_container_image_source }}"
|
||||
force_source: "{{ cadvisor_container_image_force_source }}"
|
||||
|
||||
- name: Ensure cadvisor container '{{ cadvisor_container_name }}' is {{ cadvisor_container_state }}
|
||||
community.docker.docker_container:
|
||||
name: "{{ cadvisor_container_name }}"
|
||||
image: "{{ cadvisor_container_image_ref }}"
|
||||
env: "{{ cadvisor_container_env | default(omit, true) }}"
|
||||
ports: "{{ cadvisor_container_ports | default(omit, true) }}"
|
||||
labels: "{{ cadvisor_container_labels }}"
|
||||
devices: "{{ cadvisor_container_devices }}"
|
||||
volumes: "{{ cadvisor_container_volumes }}"
|
||||
networks: "{{ cadvisor_container_networks | default(omit, true) }}"
|
||||
etc_hosts: "{{ cadvisor_container_etc_hosts | default(omit, true) }}"
|
||||
privileged: "{{ cadvisor_container_privileged }}"
|
||||
command: "{{ cadvisor_container_command }}"
|
||||
pid_mode: "{{ cadvisor_container_pid_mode | default(omit, true) }}"
|
||||
userns_mode: "{{ cadvisor_container_userns_mode | default(omit, true) }}"
|
||||
restart_policy: "{{ cadvisor_container_restart_policy }}"
|
||||
state: "{{ cadvisor_container_state }}"
|
@ -1,26 +1,18 @@
|
||||
---
|
||||
- name: Ensure state is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Unknown state '{{ cadvisor_state }}'! Supported
|
||||
states are: {{ cadvisor_states | join(', ') }}.
|
||||
when: cadvisor_state not in cadvisor_states
|
||||
|
||||
- name: Ensure container image is present
|
||||
docker_image:
|
||||
name: "{{ cadvisor_container_image_ref }}"
|
||||
state: present
|
||||
source: pull
|
||||
force_source: "{{ cadvisor_container_image_tag|default(False, True) | bool }}"
|
||||
- name: Ensure deployment method is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Unknown deployment method '{{ cadvisor_deployment_method }}'! Supported
|
||||
deployment methods are: {{ cadvisor_deployment_methods | join(', ') }}.
|
||||
when: cadvisor_deployment_method not in cadvisor_deployment_methods
|
||||
|
||||
- name: Ensure cadvisor container is running
|
||||
docker_container:
|
||||
name: "{{ cadvisor_container_name }}"
|
||||
image: "{{ cadvisor_container_image_ref }}"
|
||||
env: "{{ cadvisor_container_env | default(omit, True) }}"
|
||||
ports: "{{ cadvisor_container_ports | default(omit, True) }}"
|
||||
labels: "{{ cadvisor_container_labels }}"
|
||||
devices: "{{ cadvisor_container_devices }}"
|
||||
volumes: "{{ cadvisor_container_volumes }}"
|
||||
networks: "{{ cadvisor_container_networks | default(omit, True) }}"
|
||||
etc_hosts: "{{ cadvisor_container_etc_hosts | default(omit, True) }}"
|
||||
privileged: "{{ cadvisor_container_privileged }}"
|
||||
command: "{{ cadvisor_container_command }}"
|
||||
pid_mode: "{{ cadvisor_container_pid_mode | default(omit, True) }}"
|
||||
userns_mode: "{{ cadvisor_container_userns_mode | default(omit, True) }}"
|
||||
restart_policy: "{{ cadvisor_container_restart_policy }}"
|
||||
state: started
|
||||
- name: Deploy using {{ cadvisor_deployment_method }}
|
||||
ansible.builtin.include_tasks:
|
||||
file: "deploy-{{ cadvisor_deployment_method }}.yml"
|
||||
|
6
roles/cadvisor/vars/main.yml
Normal file
6
roles/cadvisor/vars/main.yml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
cadvisor_states:
|
||||
- present
|
||||
- absent
|
||||
cadvisor_deployment_methods:
|
||||
- docker
|
@ -1,50 +1,4 @@
|
||||
---
|
||||
grafana_user: grafana
|
||||
grafana_version: "10.1.1"
|
||||
grafana_base_path: "/opt/grafana"
|
||||
grafana_config_path: "{{ grafana_base_path }}/config"
|
||||
grafana_config_file: "{{ grafana_config_path }}/grafana.ini"
|
||||
grafana_ldap_config_file: "{{ grafana_config_path }}/ldap.toml"
|
||||
grafana_provisioning_path: "{{ grafana_config_path }}/provisioning"
|
||||
grafana_notifier_provisioning_path: "{{ grafana_provisioning_path }}/notifiers"
|
||||
grafana_dashboard_provisioning_path: "{{ grafana_provisioning_path }}/dashboards"
|
||||
grafana_datasource_provisioning_path: "{{ grafana_provisioning_path }}/datasources"
|
||||
grafana_plugin_provisioning_path: "{{ grafana_provisioning_path }}/plugins"
|
||||
grafana_data_path: "{{ grafana_base_path }}/data"
|
||||
grafana_logs_path: "{{ grafana_base_path }}/logs"
|
||||
grafana_state: present
|
||||
|
||||
grafana_run_user: >-
|
||||
{{ ('uid' in (grafana_user_info | default([]))) | ternary(grafana_user_info.uid, grafana_user) }}
|
||||
grafana_run_group: >-
|
||||
{{ ('group' in (grafana_user_info | default([]))) | ternary(grafana_user_info.group, grafana_user) }}
|
||||
|
||||
grafana_container_image_server: "docker.io"
|
||||
grafana_container_image_namespace: "grafana"
|
||||
grafana_container_image_container: "grafana"
|
||||
grafana_container_image_name: >-
|
||||
{{
|
||||
[
|
||||
((grafana_container_image_server is defined)
|
||||
| ternary([ grafana_container_image_server ], [])),
|
||||
((grafana_container_image_namespace is defined)
|
||||
| ternary([ grafana_container_image_namespace], [])),
|
||||
grafana_container_image_container,
|
||||
] | ansible.builtin.flatten | join('/')
|
||||
}}
|
||||
grafana_container_image: >-
|
||||
{{ grafana_container_image_name }}:{{ grafana_container_image_tag | default(grafana_version, true) }}
|
||||
|
||||
grafana_container_name: grafana
|
||||
grafana_container_base_volumes:
|
||||
- "{{ grafana_config_path }}:{{ grafana_container_config_path }}:ro"
|
||||
- "{{ grafana_data_path }}:{{ grafana_container_data_path }}:rw"
|
||||
- "{{ grafana_logs_path }}:{{ grafana_container_logs_path }}:rw"
|
||||
grafana_container_volumes: []
|
||||
grafana_container_collected_volumes: >-
|
||||
{{ grafana_container_base_volumes + grafana_container_volumes }}
|
||||
grafana_container_restart_policy: "unless-stopped"
|
||||
|
||||
grafana_config_log_mode:
|
||||
- console
|
||||
- file
|
26
roles/grafana/defaults/main/container.yml
Normal file
26
roles/grafana/defaults/main/container.yml
Normal file
@ -0,0 +1,26 @@
|
||||
---
|
||||
grafana_container_image_server: "docker.io"
|
||||
grafana_container_image_namespace: "grafana"
|
||||
grafana_container_image_container: "grafana"
|
||||
grafana_container_image_name: >-2
|
||||
{{
|
||||
[
|
||||
((grafana_container_image_server is defined)
|
||||
| ternary([ grafana_container_image_server ], [])),
|
||||
((grafana_container_image_namespace is defined)
|
||||
| ternary([ grafana_container_image_namespace], [])),
|
||||
grafana_container_image_container,
|
||||
] | ansible.builtin.flatten | join('/')
|
||||
}}
|
||||
grafana_container_image: >-2
|
||||
{{ grafana_container_image_name }}:{{ grafana_container_image_tag | default(grafana_version, true) }}
|
||||
|
||||
grafana_container_name: grafana
|
||||
grafana_container_base_volumes:
|
||||
- "{{ grafana_config_path }}:{{ grafana_container_config_path }}:ro"
|
||||
- "{{ grafana_data_path }}:{{ grafana_container_data_path }}:rw"
|
||||
- "{{ grafana_logs_path }}:{{ grafana_container_logs_path }}:rw"
|
||||
grafana_container_volumes: []
|
||||
grafana_container_collected_volumes: >-2
|
||||
{{ grafana_container_base_volumes + grafana_container_volumes }}
|
||||
grafana_container_restart_policy: "unless-stopped"
|
20
roles/grafana/defaults/main/main.yml
Normal file
20
roles/grafana/defaults/main/main.yml
Normal file
@ -0,0 +1,20 @@
|
||||
---
|
||||
grafana_user: grafana
|
||||
grafana_version: "11.6.1"
|
||||
grafana_base_path: "/opt/grafana"
|
||||
grafana_config_path: "{{ grafana_base_path }}/config"
|
||||
grafana_config_file: "{{ grafana_config_path }}/grafana.ini"
|
||||
grafana_ldap_config_file: "{{ grafana_config_path }}/ldap.toml"
|
||||
grafana_provisioning_path: "{{ grafana_config_path }}/provisioning"
|
||||
grafana_notifier_provisioning_path: "{{ grafana_provisioning_path }}/notifiers"
|
||||
grafana_dashboard_provisioning_path: "{{ grafana_provisioning_path }}/dashboards"
|
||||
grafana_datasource_provisioning_path: "{{ grafana_provisioning_path }}/datasources"
|
||||
grafana_plugin_provisioning_path: "{{ grafana_provisioning_path }}/plugins"
|
||||
grafana_data_path: "{{ grafana_base_path }}/data"
|
||||
grafana_logs_path: "{{ grafana_base_path }}/logs"
|
||||
grafana_state: present
|
||||
|
||||
grafana_run_user: >-
|
||||
{{ ('uid' in (grafana_user_info | default([]))) | ternary(grafana_user_info.uid, grafana_user) }}
|
||||
grafana_run_group: >-
|
||||
{{ ('group' in (grafana_user_info | default([]))) | ternary(grafana_user_info.group, grafana_user) }}
|
11
roles/grafana/meta/main.yml
Normal file
11
roles/grafana/meta/main.yml
Normal file
@ -0,0 +1,11 @@
|
||||
---
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: grafana
|
||||
description: Deploy and configure the grafana
|
||||
galaxy_tags:
|
||||
- grafana
|
||||
- monitoring
|
||||
- prometheus
|
||||
- docker
|
@ -2,7 +2,7 @@
|
||||
- name: Ensure grafana_state is valid
|
||||
ansible.builtin.assert:
|
||||
that:
|
||||
- "grafana_state in ['present', 'absent']"
|
||||
- "grafana_state in grafana_states"
|
||||
fail_msg: >-
|
||||
Only 'present' and 'absent' are allowed as values for grafana_state
|
||||
|
||||
|
@ -1,4 +1,7 @@
|
||||
---
|
||||
grafana_states:
|
||||
- present
|
||||
- absent
|
||||
grafana_container_config_path: "/etc/grafana"
|
||||
grafana_container_data_path: "/var/lib/grafana"
|
||||
grafana_container_logs_path: "/var/log/grafana"
|
||||
|
12
roles/matrix_alertmanager/meta/main.yml
Normal file
12
roles/matrix_alertmanager/meta/main.yml
Normal file
@ -0,0 +1,12 @@
|
||||
---
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: matrix_alertmanager
|
||||
description: Deploy matrix_alertmanager, an alertmanager receiver for matrix rooms
|
||||
galaxy_tags:
|
||||
- matrix_alertmanager
|
||||
- alertmanager_receiver
|
||||
- alertmanager
|
||||
- matrix
|
||||
- docker
|
@ -1,6 +1,6 @@
|
||||
---
|
||||
|
||||
postgres_exporter_version: "0.10.1"
|
||||
postgres_exporter_version: "0.15.0"
|
||||
postgres_exporter_user: root
|
||||
postgres_exporter_create_user: false
|
||||
|
||||
|
12
roles/postgres_exporter/meta/main.yml
Normal file
12
roles/postgres_exporter/meta/main.yml
Normal file
@ -0,0 +1,12 @@
|
||||
---
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: postgres_exporter
|
||||
description: Deploy and configure the prometheus-maintained postgres_exporter
|
||||
galaxy_tags:
|
||||
- postgres_exporter
|
||||
- prometheus
|
||||
- postgresql
|
||||
- postgres
|
||||
- docker
|
@ -1,7 +1,7 @@
|
||||
---
|
||||
vmagent_config_global_scrape_interval: "30s"
|
||||
vmagent_config_global_scrape_timeout: "10s"
|
||||
vmagent_config_global_external_labels: []
|
||||
vmagent_config_global_external_labels: {}
|
||||
vmagent_config_scrape_configs: []
|
||||
|
||||
vmagent_config: ~
|
||||
|
@ -29,6 +29,7 @@ vmagent_container_command: >-2
|
||||
-{{ flag }}
|
||||
{% endfor -%}
|
||||
vmagent_container_networks: ~
|
||||
vmagent_container_network_mode: ~
|
||||
vmagent_container_etc_hosts: ~
|
||||
vmagent_container_dns_servers: ~
|
||||
vmagent_container_restart_policy: >-2
|
||||
@ -52,3 +53,7 @@ vmagent_container_env: ~
|
||||
vmagent_container_merged_env: >-2
|
||||
{{ (vmagent_container_base_env | default({}, true))
|
||||
| combine(vmagent_container_env | default({})) }}
|
||||
vmagent_container_comparisons:
|
||||
env: allow_more_present
|
||||
image: strict
|
||||
labels: allow_more_present
|
||||
|
@ -1,6 +1,6 @@
|
||||
---
|
||||
vmagent_user: vmagent
|
||||
vmagent_version: "1.104.0"
|
||||
vmagent_version: "1.115.0"
|
||||
vmagent_state: present
|
||||
vmagent_deployment_method: "docker"
|
||||
|
||||
|
@ -23,5 +23,7 @@
|
||||
networks: "{{ vmagent_container_networks | default(omit, true) }}"
|
||||
etc_hosts: "{{ vmagent_container_etc_hosts | default(omit, true) }}"
|
||||
dns_servers: "{{ vmagent_container_dns_servers | default(omit, true) }}"
|
||||
network_mode: "{{ vmagent_container_network_mode | default(omit, true) }}"
|
||||
restart_policy: "{{ vmagent_container_restart_policy | default(omit, true) }}"
|
||||
comparisons: "{{ vmagent_container_comparisons | default(omit, true) }}"
|
||||
state: "{{ vmagent_container_state }}"
|
||||
|
@ -1,7 +1,7 @@
|
||||
---
|
||||
vmalert_state: present
|
||||
vmalert_user: vmalert
|
||||
vmalert_version: "1.104.0"
|
||||
vmalert_version: "1.115.0"
|
||||
vmalert_base_path: "/opt/vmalert"
|
||||
vmalert_config_path: "{{ vmalert_base_path }}/config"
|
||||
vmalert_alert_config: "{{ vmalert_config_path }}/alerts.yml"
|
||||
|
11
roles/vmalert/meta/main.yml
Normal file
11
roles/vmalert/meta/main.yml
Normal file
@ -0,0 +1,11 @@
|
||||
---
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: vmalert
|
||||
description: Deploy and configure the victoriametrics alerting engine `vmalert`
|
||||
galaxy_tags:
|
||||
- victoriametrics
|
||||
- vmalert
|
||||
- alerting
|
||||
- prometheus
|
@ -1,7 +1,7 @@
|
||||
---
|
||||
vmtsdb_state: present
|
||||
vmtsdb_user: vmtsdb
|
||||
vmtsdb_version: "1.104.0"
|
||||
vmtsdb_version: "1.115.0"
|
||||
vmtsdb_base_path: "/opt/vmtsdb"
|
||||
vmtsdb_data_path: "{{ vmtsdb_base_path }}/data"
|
||||
|
||||
|
10
roles/vmtsdb/meta/main.yml
Normal file
10
roles/vmtsdb/meta/main.yml
Normal file
@ -0,0 +1,10 @@
|
||||
---
|
||||
allow_duplicates: true
|
||||
dependencies: []
|
||||
galaxy_info:
|
||||
role_name: vmtsdb
|
||||
description: Deploy and configure the victoriametrics time-series database `vmtsdb`
|
||||
galaxy_tags:
|
||||
- victoriametrics
|
||||
- vmtsdb
|
||||
- prometheus
|
Reference in New Issue
Block a user