diff --git a/grafana_agent.yml b/grafana_agent.yml new file mode 100644 index 00000000..0ccbaeed --- /dev/null +++ b/grafana_agent.yml @@ -0,0 +1,6 @@ +--- +- hosts: all + strategy: free + roles: + - grafana_agent + become: true diff --git a/roles/grafana_agent/defaults/main.yml b/roles/grafana_agent/defaults/main.yml new file mode 100644 index 00000000..8e7358ca --- /dev/null +++ b/roles/grafana_agent/defaults/main.yml @@ -0,0 +1,15 @@ +--- +# defaults file for agent + +# Mimir URL and creds +agent_mimir_url: "http://sepia-grafana.front.sepia.ceph.com:9009/api/v1/push" +agent_mimir_username: "admin" + +# Enable metrics globally +agent_metrics: true + +# Labels used for external labels +nodetype: "unknown_nodetype" + +scrape_interval_global: "60s" +scrape_interval_node: "30s" diff --git a/roles/grafana_agent/handlers/main.yml b/roles/grafana_agent/handlers/main.yml new file mode 100644 index 00000000..169e45fd --- /dev/null +++ b/roles/grafana_agent/handlers/main.yml @@ -0,0 +1,6 @@ +--- +- name: "Restart grafana agent instance" + become: true + ansible.builtin.service: + name: "grafana-agent" + state: "restarted" diff --git a/roles/grafana_agent/meta/main.yml b/roles/grafana_agent/meta/main.yml new file mode 100644 index 00000000..313fd690 --- /dev/null +++ b/roles/grafana_agent/meta/main.yml @@ -0,0 +1,3 @@ +--- +dependencies: + - role: secrets diff --git a/roles/grafana_agent/tasks/main.yml b/roles/grafana_agent/tasks/main.yml new file mode 100644 index 00000000..42732d4d --- /dev/null +++ b/roles/grafana_agent/tasks/main.yml @@ -0,0 +1,53 @@ +--- +- name: Include secrets + include_vars: "{{ secrets_path | mandatory }}/mimir_password.yml" + no_log: true + tags: + - always + +- name: "Import Grafana GPG key" + become: true + ansible.builtin.apt_key: + url: "https://apt.grafana.com/gpg.key" + state: "present" + when: ansible_pkg_mgr == "apt" + +- name: "Add Grafana's repository to APT sources list" + become: true + ansible.builtin.apt_repository: + repo: "deb https://apt.grafana.com stable main" + state: present + when: ansible_pkg_mgr == "apt" + +- name: "Add Grafana's repository to yum/dnf systems" + become: true + ansible.builtin.yum_repository: + baseurl: "https://rpm.grafana.com" + name: "grafana" + description: "Grafana's repository" + state: present + when: ansible_os_family == "RedHat" + +- name: "Install grafana-agent" + become: true + ansible.builtin.package: + name: "grafana-agent" + state: "present" + +- name: "Enable grafana-agent" + become: true + ansible.builtin.service: + name: "grafana-agent" + state: "started" + enabled: true + +# Deploy config file from template and restart the agent +- name: "Configure agent" + become: true + ansible.builtin.template: + src: "templates/grafana-agent.yaml.j2" + dest: "/etc/grafana-agent.yaml" + mode: "0440" + owner: "root" + group: "grafana-agent" + notify: "Restart grafana agent instance" diff --git a/roles/grafana_agent/templates/grafana-agent.yaml.j2 b/roles/grafana_agent/templates/grafana-agent.yaml.j2 new file mode 100644 index 00000000..03b58c2f --- /dev/null +++ b/roles/grafana_agent/templates/grafana-agent.yaml.j2 @@ -0,0 +1,35 @@ +server: + log_level: info + +{% if agent_metrics %} +metrics: + global: + remote_write: + - url: {{ agent_mimir_url }} + basic_auth: + username: {{ agent_mimir_username }} + password: {{ agent_mimir_password }} + queue_config: + max_backoff: 5m + external_labels: + nodetype: {{ nodetype }} + ingest_instance: {{ inventory_hostname }} + scrape_interval: {{ scrape_interval_global }} + configs: + - name: {{ inventory_hostname }} + scrape_configs: + - job_name: 'grafana-agent-exporter' + relabel_configs: + - source_labels: [__address__] + target_label: instance + replacement: {{ inventory_hostname }} +{% endif %} + +integrations: + node_exporter: + enabled: true + scrape_interval: {{ scrape_interval_node }} + instance: {{ inventory_hostname }} + rootfs_path: / + sysfs_path: /sys + procfs_path: /proc