diff options
author | Sam Chudnick <sam@chudnick.com> | 2023-06-25 09:52:36 -0400 |
---|---|---|
committer | Sam Chudnick <sam@chudnick.com> | 2023-06-25 09:52:36 -0400 |
commit | 95b73daa36b23565a8566f71f9b202d3459b685f (patch) | |
tree | cb17b021be70e7868d0ec235a761f0ecdc80f3f2 /roles/services/monitoring |
Diffstat (limited to 'roles/services/monitoring')
18 files changed, 624 insertions, 0 deletions
diff --git a/roles/services/monitoring/grafana/defaults/main.yml b/roles/services/monitoring/grafana/defaults/main.yml new file mode 100644 index 0000000..c346e54 --- /dev/null +++ b/roles/services/monitoring/grafana/defaults/main.yml | |||
@@ -0,0 +1,5 @@ | |||
1 | grafana_package: | ||
2 | - grafana | ||
3 | - nginx | ||
4 | grafana_config: files/grafana_config/ | ||
5 | grafana_data: files/grafana.db | ||
diff --git a/roles/services/monitoring/grafana/handlers/main.yml b/roles/services/monitoring/grafana/handlers/main.yml new file mode 100644 index 0000000..8026c6d --- /dev/null +++ b/roles/services/monitoring/grafana/handlers/main.yml | |||
@@ -0,0 +1,13 @@ | |||
1 | - name: update repos | ||
2 | apt: | ||
3 | update_cache: yes | ||
4 | |||
5 | - name: restart grafana | ||
6 | service: | ||
7 | name: grafana-server | ||
8 | state: restarted | ||
9 | |||
10 | - name: restart nginx | ||
11 | service: | ||
12 | name: nginx | ||
13 | state: restarted | ||
diff --git a/roles/services/monitoring/grafana/tasks/main.yml b/roles/services/monitoring/grafana/tasks/main.yml new file mode 100644 index 0000000..e9f824e --- /dev/null +++ b/roles/services/monitoring/grafana/tasks/main.yml | |||
@@ -0,0 +1,125 @@ | |||
1 | - name: install extrepo | ||
2 | package: | ||
3 | name: extrepo | ||
4 | state: latest | ||
5 | |||
6 | - name: add Grafana repo | ||
7 | register: result | ||
8 | changed_when: result.stdout | regex_search("skipped") | bool | ||
9 | notify: update repos | ||
10 | command: | ||
11 | cmd: extrepo enable grafana | ||
12 | creates: /etc/apt/sources.list.d/extrepo_grafana.sources | ||
13 | |||
14 | - meta: flush_handlers | ||
15 | |||
16 | - name: update Grafana repo | ||
17 | changed_when: false | ||
18 | command: | ||
19 | cmd: extrepo update grafana | ||
20 | |||
21 | - name: install grafana | ||
22 | package: | ||
23 | name: "{{ grafana_package }}" | ||
24 | |||
25 | - name: deploy grafana config | ||
26 | notify: restart grafana | ||
27 | template: | ||
28 | src: "{{ grafana_config }}" | ||
29 | dest: /etc/grafana/grafana.ini | ||
30 | owner: root | ||
31 | group: grafana | ||
32 | mode: '0640' | ||
33 | |||
34 | - name: deploy nginx configuration | ||
35 | notify: restart nginx | ||
36 | copy: | ||
37 | src: "{{ grafana_nginx_config }}" | ||
38 | dest: /etc/nginx/sites-available/grafana.conf | ||
39 | owner: root | ||
40 | group: root | ||
41 | mode: '0644' | ||
42 | |||
43 | - name: symlink site | ||
44 | notify: restart nginx | ||
45 | file: | ||
46 | src: /etc/nginx/sites-available/grafana.conf | ||
47 | dest: /etc/nginx/sites-enabled/grafana.conf | ||
48 | owner: root | ||
49 | group: root | ||
50 | state: link | ||
51 | |||
52 | - name: allow http (80/tcp) traffic | ||
53 | ufw: | ||
54 | rule: allow | ||
55 | port: '80' | ||
56 | proto: tcp | ||
57 | |||
58 | - name: allow https (443/tcp) traffic | ||
59 | ufw: | ||
60 | rule: allow | ||
61 | port: '443' | ||
62 | proto: tcp | ||
63 | |||
64 | - name: enable grafana | ||
65 | systemd: | ||
66 | daemon_reload: yes | ||
67 | enabled: yes | ||
68 | masked: no | ||
69 | name: grafana-server | ||
70 | |||
71 | - meta: flush_handlers | ||
72 | |||
73 | - name: add grafana user | ||
74 | ignore_errors: yes | ||
75 | community.grafana.grafana_user: | ||
76 | name: "{{ grafana_admin }}" | ||
77 | email: "{{ grafana_email }}" | ||
78 | url: "{{ grafana_url }}" | ||
79 | login: "{{ grafana_admin }}" | ||
80 | password: "{{ grafana_password }}" | ||
81 | is_admin: true | ||
82 | state: present | ||
83 | |||
84 | - name: add prometheus datasource | ||
85 | community.grafana.grafana_datasource: | ||
86 | grafana_url: "{{ grafana_url }}" | ||
87 | grafana_user: "{{ grafana_admin }}" | ||
88 | grafana_password: "{{ grafana_password }}" | ||
89 | name: "Prometheus" | ||
90 | ds_type: prometheus | ||
91 | ds_url: "{{ prometheus_url }}" | ||
92 | access: proxy | ||
93 | |||
94 | - name: add influxdb datasource | ||
95 | community.grafana.grafana_datasource: | ||
96 | grafana_url: "{{ grafana_url }}" | ||
97 | grafana_user: "{{ grafana_admin }}" | ||
98 | grafana_password: "{{ grafana_password }}" | ||
99 | name: "Proxmox InfluxDB" | ||
100 | ds_type: influxdb | ||
101 | ds_url: "{{ influxdb_url }}" | ||
102 | database: "{{ influx_database }}" | ||
103 | user: "{{ influx_user }}" | ||
104 | password: "{{ influx_password }}" | ||
105 | access: proxy | ||
106 | |||
107 | - name: add loki datasource | ||
108 | community.grafana.grafana_datasource: | ||
109 | grafana_url: "{{ grafana_url }}" | ||
110 | grafana_user: "{{ grafana_admin }}" | ||
111 | grafana_password: "{{ grafana_password }}" | ||
112 | name: "Loki" | ||
113 | ds_type: loki | ||
114 | ds_url: "{{ loki_url }}" | ||
115 | access: proxy | ||
116 | |||
117 | - name: import main custom dashboard | ||
118 | delegate_to: localhost | ||
119 | become: no | ||
120 | community.grafana.grafana_dashboard: | ||
121 | grafana_url: "{{ grafana_url }}" | ||
122 | grafana_user: "{{ grafana_admin }}" | ||
123 | grafana_password: "{{ grafana_password }}" | ||
124 | path: "{{ grafana_dashboard_main }}" | ||
125 | overwrite: yes | ||
diff --git a/roles/services/monitoring/influxdb/defaults/main.yml b/roles/services/monitoring/influxdb/defaults/main.yml new file mode 100644 index 0000000..180ad8e --- /dev/null +++ b/roles/services/monitoring/influxdb/defaults/main.yml | |||
@@ -0,0 +1,6 @@ | |||
1 | influxdb_packages: | ||
2 | - influxdb | ||
3 | - influxdb-client | ||
4 | |||
5 | influx_config: files/influxdb.conf | ||
6 | influx_data: files/influx_data/ | ||
diff --git a/roles/services/monitoring/influxdb/handlers/main.yml b/roles/services/monitoring/influxdb/handlers/main.yml new file mode 100644 index 0000000..765a040 --- /dev/null +++ b/roles/services/monitoring/influxdb/handlers/main.yml | |||
@@ -0,0 +1,4 @@ | |||
1 | - name: restart influxdb | ||
2 | service: | ||
3 | name: influxdb | ||
4 | state: restarted | ||
diff --git a/roles/services/monitoring/influxdb/tasks/main.yml b/roles/services/monitoring/influxdb/tasks/main.yml new file mode 100644 index 0000000..06d6e86 --- /dev/null +++ b/roles/services/monitoring/influxdb/tasks/main.yml | |||
@@ -0,0 +1,19 @@ | |||
1 | - name: install packages | ||
2 | package: | ||
3 | name: "{{ influxdb_packages }}" | ||
4 | state: latest | ||
5 | |||
6 | - name: copy config | ||
7 | notify: restart influxdb | ||
8 | copy: | ||
9 | src: "{{ influx_config }}" | ||
10 | dest: /etc/influxdb/influxdb.conf | ||
11 | owner: root | ||
12 | group: root | ||
13 | mode: '0644' | ||
14 | |||
15 | - name: enable influxdb | ||
16 | systemd: | ||
17 | name: influxdb | ||
18 | enabled: yes | ||
19 | masked: no | ||
diff --git a/roles/services/monitoring/loki/handlers/main.yml b/roles/services/monitoring/loki/handlers/main.yml new file mode 100644 index 0000000..e70412f --- /dev/null +++ b/roles/services/monitoring/loki/handlers/main.yml | |||
@@ -0,0 +1,8 @@ | |||
1 | - name: update repos | ||
2 | apt: | ||
3 | update_cache: yes | ||
4 | |||
5 | - name: restart nginx | ||
6 | service: | ||
7 | name: nginx | ||
8 | state: restarted | ||
diff --git a/roles/services/monitoring/loki/tasks/main.yml b/roles/services/monitoring/loki/tasks/main.yml new file mode 100644 index 0000000..31a7375 --- /dev/null +++ b/roles/services/monitoring/loki/tasks/main.yml | |||
@@ -0,0 +1,80 @@ | |||
1 | - name: install extrepo | ||
2 | package: | ||
3 | name: extrepo | ||
4 | state: latest | ||
5 | |||
6 | - name: add Grafana repo | ||
7 | register: result | ||
8 | changed_when: result.stdout | regex_search("skipped") | bool | ||
9 | notify: update repos | ||
10 | command: | ||
11 | cmd: extrepo enable grafana | ||
12 | creates: /etc/apt/sources.list.d/extrepo_grafana.sources | ||
13 | |||
14 | - meta: flush_handlers | ||
15 | |||
16 | - name: add Grafana repo | ||
17 | changed_when: false | ||
18 | command: | ||
19 | cmd: extrepo update grafana | ||
20 | |||
21 | - name: install loki | ||
22 | package: | ||
23 | name: loki | ||
24 | state: latest | ||
25 | |||
26 | - name: deploy loki configuration | ||
27 | copy: | ||
28 | src: "{{ loki_config }}" | ||
29 | dest: /etc/loki/config.yml | ||
30 | owner: root | ||
31 | group: root | ||
32 | mode: '0644' | ||
33 | |||
34 | - name: deploy nginx configuration | ||
35 | copy: | ||
36 | src: "{{ loki_nginx_config }}" | ||
37 | dest: /etc/nginx/sites-available/loki.conf | ||
38 | owner: root | ||
39 | group: root | ||
40 | mode: '0644' | ||
41 | register: nginxconfig | ||
42 | notify: restart nginx | ||
43 | |||
44 | - name: symlink site | ||
45 | file: | ||
46 | src: /etc/nginx/sites-available/loki.conf | ||
47 | dest: /etc/nginx/sites-enabled/loki.conf | ||
48 | owner: root | ||
49 | group: root | ||
50 | state: link | ||
51 | |||
52 | - name: allow http (80/tcp) traffic | ||
53 | ufw: | ||
54 | rule: allow | ||
55 | port: '80' | ||
56 | proto: tcp | ||
57 | |||
58 | - name: allow https (443/tcp) traffic | ||
59 | ufw: | ||
60 | rule: allow | ||
61 | port: '443' | ||
62 | proto: tcp | ||
63 | |||
64 | - name: allow loki log (3100/tcp) traffic | ||
65 | ufw: | ||
66 | rule: allow | ||
67 | port: '3100' | ||
68 | proto: tcp | ||
69 | |||
70 | - name: enable loki | ||
71 | systemd: | ||
72 | daemon_reload: yes | ||
73 | enabled: yes | ||
74 | masked: no | ||
75 | name: loki | ||
76 | |||
77 | - name: restart loki | ||
78 | systemd: | ||
79 | name: loki | ||
80 | state: restarted | ||
diff --git a/roles/services/monitoring/prometheus/blackbox-exporter/tasks/main.yml b/roles/services/monitoring/prometheus/blackbox-exporter/tasks/main.yml new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/roles/services/monitoring/prometheus/blackbox-exporter/tasks/main.yml | |||
diff --git a/roles/services/monitoring/prometheus/nginx_exporter/defaults/main.yml b/roles/services/monitoring/prometheus/nginx_exporter/defaults/main.yml new file mode 100644 index 0000000..9d2b8a5 --- /dev/null +++ b/roles/services/monitoring/prometheus/nginx_exporter/defaults/main.yml | |||
@@ -0,0 +1,4 @@ | |||
1 | nginx_exporter_debian_package: prometheus-nginx-exporter | ||
2 | nginx_exporter_fedora_package: golang-github-prometheus-node-exporter | ||
3 | prometheus_server_ip: 192.168.88.32 | ||
4 | nginx_exporter_port: '9113' | ||
diff --git a/roles/services/monitoring/prometheus/nginx_exporter/handlers/main.yml b/roles/services/monitoring/prometheus/nginx_exporter/handlers/main.yml new file mode 100644 index 0000000..fe9a90d --- /dev/null +++ b/roles/services/monitoring/prometheus/nginx_exporter/handlers/main.yml | |||
@@ -0,0 +1,9 @@ | |||
1 | - name: restart nginx | ||
2 | service: | ||
3 | name: nginx | ||
4 | state: restarted | ||
5 | |||
6 | - name: restart nginx-exporter | ||
7 | service: | ||
8 | name: prometheus-nginx-exporter | ||
9 | state: started | ||
diff --git a/roles/services/monitoring/prometheus/nginx_exporter/tasks/main.yml b/roles/services/monitoring/prometheus/nginx_exporter/tasks/main.yml new file mode 100644 index 0000000..819f71e --- /dev/null +++ b/roles/services/monitoring/prometheus/nginx_exporter/tasks/main.yml | |||
@@ -0,0 +1,44 @@ | |||
1 | - name: install package (Debian) | ||
2 | when: ansible_facts['distribution'] == "Debian" | ||
3 | package: | ||
4 | name: "{{ nginx_exporter_debian_package }}" | ||
5 | |||
6 | - name: allow port | ||
7 | ufw: | ||
8 | rule: allow | ||
9 | direction: in | ||
10 | proto: tcp | ||
11 | src: "{{ prometheus_server_ip }}" | ||
12 | to_port: "{{ nginx_exporter_port }}" | ||
13 | |||
14 | - name: copy defaults file | ||
15 | notify: restart nginx-exporter | ||
16 | copy: | ||
17 | src: "{{ nginx_exporter_defaults }}" | ||
18 | dest: /etc/default/prometheus-nginx-exporter | ||
19 | owner: root | ||
20 | group: root | ||
21 | mode: '0644' | ||
22 | |||
23 | - name: deploy nginx configuration | ||
24 | notify: restart nginx | ||
25 | copy: | ||
26 | src: "{{ nginx_exporter_config }}" | ||
27 | dest: /etc/nginx/sites-available/metrics.conf | ||
28 | owner: root | ||
29 | group: root | ||
30 | mode: '0644' | ||
31 | |||
32 | - name: symlink site | ||
33 | file: | ||
34 | src: /etc/nginx/sites-available/metrics.conf | ||
35 | dest: /etc/nginx/sites-enabled/metrics.conf | ||
36 | owner: root | ||
37 | group: root | ||
38 | state: link | ||
39 | |||
40 | - name: enable service | ||
41 | systemd: | ||
42 | name: prometheus-nginx-exporter | ||
43 | enabled: yes | ||
44 | masked: no | ||
diff --git a/roles/services/monitoring/prometheus/node_exporter/defaults/main.yml b/roles/services/monitoring/prometheus/node_exporter/defaults/main.yml new file mode 100644 index 0000000..e4ff351 --- /dev/null +++ b/roles/services/monitoring/prometheus/node_exporter/defaults/main.yml | |||
@@ -0,0 +1,4 @@ | |||
1 | node_exporter_debian_package: prometheus-node-exporter | ||
2 | node_exporter_fedora_package: golang-github-prometheus-node-exporter | ||
3 | prometheus_server_ip: 192.168.88.32 | ||
4 | node_exporter_port: '9100' | ||
diff --git a/roles/services/monitoring/prometheus/node_exporter/tasks/main.yml b/roles/services/monitoring/prometheus/node_exporter/tasks/main.yml new file mode 100644 index 0000000..6bbcc08 --- /dev/null +++ b/roles/services/monitoring/prometheus/node_exporter/tasks/main.yml | |||
@@ -0,0 +1,28 @@ | |||
1 | - name: install package (Debian) | ||
2 | when: ansible_facts['distribution'] == "Debian" | ||
3 | package: | ||
4 | name: "{{ node_exporter_debian_package }}" | ||
5 | |||
6 | - name: install package (Fedora) | ||
7 | when: ansible_facts['distribution'] == "Fedora" | ||
8 | package: | ||
9 | name: "{{ node_exporter_fedora_package }}" | ||
10 | |||
11 | - name: allow port | ||
12 | ufw: | ||
13 | rule: allow | ||
14 | direction: in | ||
15 | proto: tcp | ||
16 | src: "{{ prometheus_server_ip }}" | ||
17 | to_port: "{{ node_exporter_port }}" | ||
18 | |||
19 | - name: enable service | ||
20 | systemd: | ||
21 | name: prometheus-node-exporter | ||
22 | enabled: yes | ||
23 | masked: no | ||
24 | |||
25 | - name: restart service | ||
26 | service: | ||
27 | name: prometheus-node-exporter | ||
28 | state: restarted | ||
diff --git a/roles/services/monitoring/prometheus/server/defaults/main.yml b/roles/services/monitoring/prometheus/server/defaults/main.yml new file mode 100644 index 0000000..696e7cc --- /dev/null +++ b/roles/services/monitoring/prometheus/server/defaults/main.yml | |||
@@ -0,0 +1,6 @@ | |||
1 | prometheus_package: prometheus | ||
2 | management_ip: 192.168.88.254 | ||
3 | grafana_server_ip: 192.168.88.21 | ||
4 | prometheus_port: '9090' | ||
5 | prometheus_config: files/prometheus.yml | ||
6 | prometheus_defaults: files/prometheus | ||
diff --git a/roles/services/monitoring/prometheus/server/tasks/main.yml b/roles/services/monitoring/prometheus/server/tasks/main.yml new file mode 100644 index 0000000..06ecc10 --- /dev/null +++ b/roles/services/monitoring/prometheus/server/tasks/main.yml | |||
@@ -0,0 +1,79 @@ | |||
1 | - name: install package | ||
2 | package: | ||
3 | name: "{{ prometheus_package }}" | ||
4 | |||
5 | - name: allow access to metrics from grafana | ||
6 | ufw: | ||
7 | rule: allow | ||
8 | direction: in | ||
9 | proto: tcp | ||
10 | src: "{{ grafana_server_ip }}" | ||
11 | to_port: "{{ prometheus_port }}" | ||
12 | |||
13 | - name: allow access to metrics from management | ||
14 | ufw: | ||
15 | rule: allow | ||
16 | direction: in | ||
17 | proto: tcp | ||
18 | src: "{{ management_ip }}" | ||
19 | to_port: "{{ prometheus_port }}" | ||
20 | |||
21 | - name: copy config file | ||
22 | copy: | ||
23 | src: "{{ prometheus_config }}" | ||
24 | dest: /etc/prometheus/prometheus.yml | ||
25 | owner: root | ||
26 | group: root | ||
27 | mode: '0644' | ||
28 | |||
29 | - name: copy defaults file | ||
30 | copy: | ||
31 | src: "{{ prometheus_defaults }}" | ||
32 | dest: /etc/default/prometheus | ||
33 | owner: root | ||
34 | group: root | ||
35 | mode: '0644' | ||
36 | |||
37 | - name: enable service | ||
38 | systemd: | ||
39 | name: prometheus | ||
40 | enabled: yes | ||
41 | masked: no | ||
42 | |||
43 | - name: restart service | ||
44 | service: | ||
45 | name: prometheus | ||
46 | state: restarted | ||
47 | |||
48 | - name: deploy nginx configuration | ||
49 | copy: | ||
50 | src: "{{ prometheus_nginx_config }}" | ||
51 | dest: /etc/nginx/sites-available/grafana.conf | ||
52 | owner: root | ||
53 | group: root | ||
54 | mode: '0644' | ||
55 | |||
56 | - name: symlink site | ||
57 | file: | ||
58 | src: /etc/nginx/sites-available/grafana.conf | ||
59 | dest: /etc/nginx/sites-enabled/grafana.conf | ||
60 | owner: root | ||
61 | group: root | ||
62 | state: link | ||
63 | |||
64 | - name: allow http (80/tcp) traffic | ||
65 | ufw: | ||
66 | rule: allow | ||
67 | port: '80' | ||
68 | proto: tcp | ||
69 | |||
70 | - name: allow https (443/tcp) traffic | ||
71 | ufw: | ||
72 | rule: allow | ||
73 | port: '443' | ||
74 | proto: tcp | ||
75 | |||
76 | - name: restart nginx | ||
77 | service: | ||
78 | name: nginx | ||
79 | state: restarted | ||
diff --git a/roles/services/monitoring/promtail/handlers/main.yml b/roles/services/monitoring/promtail/handlers/main.yml new file mode 100644 index 0000000..97ea7d3 --- /dev/null +++ b/roles/services/monitoring/promtail/handlers/main.yml | |||
@@ -0,0 +1,39 @@ | |||
1 | - name: update repos - debian | ||
2 | apt: | ||
3 | update_cache: yes | ||
4 | |||
5 | - name: update repos - fedora | ||
6 | dnf: | ||
7 | name: "*" | ||
8 | state: latest | ||
9 | |||
10 | - name: build loki-docker-driver plugin for private repo | ||
11 | become: yes | ||
12 | become_user: "{{ docker_username }}" | ||
13 | environment: | ||
14 | LOKI_DOCKER_DRIVER: "{{ docker_registry_url }}/{{ docker_registry_username }}/loki-docker-driver" | ||
15 | community.general.make: | ||
16 | chdir: "{{ docker_home }}/plugins/loki" | ||
17 | target: docker-driver-push | ||
18 | |||
19 | - name: restart rootless docker | ||
20 | become: yes | ||
21 | become_user: "{{ docker_username }}" | ||
22 | systemd: | ||
23 | name: docker | ||
24 | enabled: yes | ||
25 | state: restarted | ||
26 | scope: user | ||
27 | environment: | ||
28 | XDG_RUNTIME_DIR: "/run/user/{{ docker_uid }}" | ||
29 | |||
30 | - name: restart docker | ||
31 | service: | ||
32 | name: docker | ||
33 | state: restarted | ||
34 | |||
35 | - name: restart promtail | ||
36 | when: promtail_config.changed | ||
37 | service: | ||
38 | name: promtail | ||
39 | state: restarted | ||
diff --git a/roles/services/monitoring/promtail/tasks/main.yml b/roles/services/monitoring/promtail/tasks/main.yml new file mode 100644 index 0000000..f8b28cc --- /dev/null +++ b/roles/services/monitoring/promtail/tasks/main.yml | |||
@@ -0,0 +1,151 @@ | |||
1 | - name: install extrepo | ||
2 | when: ansible_facts['distribution'] == 'Debian' | ||
3 | package: | ||
4 | name: extrepo | ||
5 | state: latest | ||
6 | |||
7 | - name: add grafana repo | debian | ||
8 | when: ansible_facts['distribution'] == 'Debian' | ||
9 | register: result | ||
10 | changed_when: result.stdout | regex_search("skipped") | bool | ||
11 | notify: update repos - debian | ||
12 | command: | ||
13 | cmd: extrepo enable grafana | ||
14 | creates: /etc/apt/sources.list.d/extrepo_grafana.sources | ||
15 | |||
16 | - meta: flush_handlers | ||
17 | |||
18 | - name: update grafana extrepo data | debian | ||
19 | when: ansible_facts['distribution'] == 'Debian' | ||
20 | changed_when: false | ||
21 | command: | ||
22 | cmd: extrepo update grafana | ||
23 | |||
24 | - name: add Grafana repo | fedora | ||
25 | when: ansible_facts['distribution'] == 'Fedora' | ||
26 | notify: update repos - fedora | ||
27 | yum_repository: | ||
28 | name: grafana | ||
29 | file: grafna | ||
30 | description: "Grafana OSS Repo" | ||
31 | baseurl: "https://rpm.grafana.com" | ||
32 | repo_gpgcheck: yes | ||
33 | enabled: yes | ||
34 | gpgcheck: yes | ||
35 | gpgkey: https://rpm.grafana.com/gpg.key | ||
36 | sslverify: yes | ||
37 | sslcacert: /etc/pki/tls/certs/ca-bundle.crt | ||
38 | exclude: "*beta*" | ||
39 | |||
40 | - name: install promtail | ||
41 | package: | ||
42 | name: promtail | ||
43 | state: latest | ||
44 | |||
45 | - name: add promtail to adm group for log access (debian) | ||
46 | when: ansible_facts['distribution'] == 'Debian' | ||
47 | user: | ||
48 | name: promtail | ||
49 | groups: adm | ||
50 | append: yes | ||
51 | |||
52 | - name: add promtail to systemd-journal group for journal access | ||
53 | user: | ||
54 | name: promtail | ||
55 | groups: systemd-journal | ||
56 | append: yes | ||
57 | |||
58 | - name: create docker plugin directory | ||
59 | when: "'docker_hosts' in group_names" | ||
60 | become: yes | ||
61 | become_user: "{{ docker_username }}" | ||
62 | file: | ||
63 | path: "{{ docker_home }}/plugins" | ||
64 | state: directory | ||
65 | owner: "{{ docker_username }}" | ||
66 | group: "{{ docker_username }}" | ||
67 | mode: "0755" | ||
68 | |||
69 | - name: clone loki repo | ||
70 | when: "'docker_hosts' in group_names" | ||
71 | become: yes | ||
72 | become_user: "{{ docker_username }}" | ||
73 | git: | ||
74 | repo: "{{ loki_repo }}" | ||
75 | dest: "{{ docker_home }}/plugins/loki" | ||
76 | version: "{{ loki_version }}" | ||
77 | register: repo | ||
78 | notify: build loki-docker-driver plugin for private repo | ||
79 | |||
80 | - meta: flush_handlers | ||
81 | |||
82 | - name: login to docker registry | ||
83 | when: "'docker_hosts' in group_names" | ||
84 | become: yes | ||
85 | become_user: "{{ docker_username }}" | ||
86 | environment: | ||
87 | XDG_RUNTIME_DIR: "/run/user/{{ docker_uid }}" | ||
88 | docker_login: | ||
89 | docker_host: "unix://run/user/{{ docker_uid }}/docker.sock" | ||
90 | registry_url: "{{ docker_registry_url }}" | ||
91 | username: "{{ docker_registry_username }}" | ||
92 | password: "{{ docker_registry_password }}" | ||
93 | |||
94 | # docker driver rootless | ||
95 | |||
96 | - name: enable loki-docker-driver plugin | ||
97 | when: "'docker_hosts' in group_names" | ||
98 | become: yes | ||
99 | become_user: "{{ docker_username }}" | ||
100 | notify: restart rootless docker | ||
101 | community.docker.docker_plugin: | ||
102 | plugin_name: "{{ docker_registry_url }}/{{ docker_registry_username }}/loki-docker-driver:main" | ||
103 | state: enable | ||
104 | docker_host: "unix://run/user/{{ docker_uid }}/docker.sock" | ||
105 | alias: loki | ||
106 | |||
107 | - name: deploy docker config | ||
108 | when: "'docker_hosts' in group_names" | ||
109 | notify: restart rootless docker | ||
110 | copy: | ||
111 | src: "{{ docker_config }}" | ||
112 | dest: "{{ docker_home }}/.config/docker/daemon.json" | ||
113 | owner: "{{ docker_username }}" | ||
114 | group: "{{ docker_username }}" | ||
115 | mode: '0644' | ||
116 | |||
117 | # docker driver root | ||
118 | |||
119 | - name: enable loki-docker-driver plugin | ||
120 | when: "'docker_hosts' in group_names" | ||
121 | notify: restart docker | ||
122 | community.docker.docker_plugin: | ||
123 | plugin_name: "{{ docker_registry_url }}/{{ docker_registry_username }}/loki-docker-driver:main" | ||
124 | state: enable | ||
125 | alias: loki | ||
126 | |||
127 | - name: deploy docker config | ||
128 | when: "'docker_hosts' in group_names" | ||
129 | notify: restart docker | ||
130 | copy: | ||
131 | src: "{{ docker_config }}" | ||
132 | dest: /etc/docker/daemon.json | ||
133 | owner: root | ||
134 | group: root | ||
135 | mode: '0644' | ||
136 | |||
137 | - name: deploy promtail configuration | ||
138 | notify: restart promtail | ||
139 | copy: | ||
140 | src: "{{ promtail_config }}" | ||
141 | dest: /etc/promtail/config.yml | ||
142 | owner: root | ||
143 | group: root | ||
144 | mode: '0644' | ||
145 | |||
146 | - name: enable promtail | ||
147 | systemd: | ||
148 | daemon_reload: yes | ||
149 | enabled: yes | ||
150 | masked: no | ||
151 | name: promtail | ||