88 lines
2.5 KiB
YAML
88 lines
2.5 KiB
YAML
---
|
|
- name: "Install Netdata monitoring service"
|
|
hosts: all
|
|
|
|
vars_files:
|
|
- vars/ports.yml
|
|
- vars/vars.yml
|
|
|
|
vars:
|
|
app_name: "netdata"
|
|
app_user: "{{ app_name }}"
|
|
base_dir: "/home/{{ app_user }}"
|
|
config_dir: "{{ (base_dir, 'config') | path_join }}"
|
|
config_go_d_dir: "{{ (config_dir, 'go.d') | path_join }}"
|
|
data_dir: "{{ (base_dir, 'data') | path_join }}"
|
|
|
|
tasks:
|
|
- name: "Create user and environment"
|
|
ansible.builtin.import_role:
|
|
name: owner
|
|
vars:
|
|
owner_name: "{{ app_user }}"
|
|
owner_extra_groups: ["docker"]
|
|
|
|
- name: "Create internal application directories"
|
|
ansible.builtin.file:
|
|
path: "{{ item }}"
|
|
state: "directory"
|
|
owner: "{{ app_user }}"
|
|
group: "{{ app_user }}"
|
|
mode: "0770"
|
|
loop:
|
|
- "{{ config_dir }}"
|
|
- "{{ config_go_d_dir }}"
|
|
- "{{ data_dir }}"
|
|
|
|
- name: "Copy netdata config file"
|
|
ansible.builtin.template:
|
|
src: "files/{{ app_name }}/netdata.conf.j2"
|
|
dest: "{{ config_dir }}/netdata.conf"
|
|
owner: "{{ app_user }}"
|
|
group: "{{ app_user }}"
|
|
mode: "0640"
|
|
|
|
- name: "Copy prometheus plugin config file"
|
|
ansible.builtin.copy:
|
|
src: "files/{{ app_name }}/go.d/prometheus.conf"
|
|
dest: "{{ config_go_d_dir }}/prometheus.conf"
|
|
owner: "{{ app_user }}"
|
|
group: "{{ app_user }}"
|
|
mode: "0640"
|
|
|
|
- name: "Copy fail2ban plugin config file"
|
|
ansible.builtin.copy:
|
|
src: "files/{{ app_name }}/go.d/fail2ban.conf"
|
|
dest: "{{ config_go_d_dir }}/fail2ban.conf"
|
|
owner: "{{ app_user }}"
|
|
group: "{{ app_user }}"
|
|
mode: "0640"
|
|
|
|
- name: "Grab docker group id."
|
|
ansible.builtin.shell:
|
|
cmd: |
|
|
set -o pipefail
|
|
grep docker /etc/group | cut -d ':' -f 3
|
|
executable: /bin/bash
|
|
register: netdata_docker_group_output
|
|
changed_when: netdata_docker_group_output.rc != 0
|
|
|
|
- name: "Copy docker compose file"
|
|
ansible.builtin.template:
|
|
src: "./files/{{ app_name }}/docker-compose.yml.j2"
|
|
dest: "{{ base_dir }}/docker-compose.yml"
|
|
owner: "{{ app_user }}"
|
|
group: "{{ app_user }}"
|
|
mode: "0640"
|
|
|
|
- name: "Run application with docker compose"
|
|
community.docker.docker_compose_v2:
|
|
project_src: "{{ base_dir }}"
|
|
state: "present"
|
|
remove_orphans: true
|
|
|
|
- name: "Restart application with docker compose"
|
|
community.docker.docker_compose_v2:
|
|
project_src: "{{ base_dir }}"
|
|
state: "restarted"
|