Add support for custom grafana dashboards

Allow users to import custom grafana dashboards.
Dashboards as JSON files should be placed into
"{{ node_custom_config }}/grafana/dashboards/" folder.

Change-Id: Id0f83b8d08541b3b74649f097b10c9450201b426
This commit is contained in:
Bartosz Bezak 2020-12-22 16:35:43 +01:00
parent 4b51997e7b
commit a9e30382fe
6 changed files with 145 additions and 0 deletions

View File

@ -102,3 +102,71 @@
- "prometheus.yaml.j2" - "prometheus.yaml.j2"
notify: notify:
- Restart grafana container - Restart grafana container
- name: Configuring dashboards provisioning
vars:
service: "{{ grafana_services['grafana'] }}"
template:
src: "{{ item }}"
dest: "{{ node_config_directory }}/grafana/provisioning.yaml"
mode: "0660"
become: true
when:
- inventory_hostname in groups[service.group]
- service.enabled | bool
with_first_found:
- "{{ node_custom_config }}/grafana/{{ inventory_hostname }}/provisioning.yaml"
- "{{ node_custom_config }}/grafana/provisioning.yaml"
- "{{ role_path }}/templates/provisioning.yaml.j2"
notify:
- Restart grafana container
- name: Check if the folder for custom grafana dashboards exists
stat:
path: "{{ node_custom_config }}/grafana/dashboards"
delegate_to: localhost
register: grafana_custom_dashboards_folder
run_once: True
- name: Remove templated Grafana dashboards
become: true
vars:
service: "{{ grafana_services['grafana'] }}"
file:
state: absent
path: "{{ node_config_directory }}/grafana/dashboards/"
when:
- inventory_hostname in groups[service.group]
- service.enabled | bool
- name: Create custom Grafana dashboards folder
become: true
vars:
service: "{{ grafana_services['grafana'] }}"
file:
dest: "{{ node_config_directory }}/grafana/dashboards/"
state: "directory"
mode: "0770"
when:
- grafana_custom_dashboards_folder.stat.exists
- grafana_custom_dashboards_folder.stat.isdir
- inventory_hostname in groups[service.group]
- service.enabled | bool
- name: Copying over custom dashboards
vars:
service: "{{ grafana_services['grafana'] }}"
copy:
src: "{{ item }}"
dest: "{{ node_config_directory }}/grafana/dashboards/"
mode: "0660"
become: true
when:
- grafana_custom_dashboards_folder.stat.exists
- grafana_custom_dashboards_folder.stat.isdir
- inventory_hostname in groups[service.group]
- service.enabled | bool
with_fileglob:
- "{{ node_custom_config }}/grafana/dashboards/*.json"
notify:
- Restart grafana container

View File

@ -28,6 +28,19 @@
"owner": "root", "owner": "root",
"perm": "0644", "perm": "0644",
"optional": true "optional": true
},
{
"source": "{{ container_config_directory }}/provisioning.yaml",
"dest": "/etc/grafana/provisioning/dashboards/provisioning.yaml",
"owner": "root",
"perm": "0644"
},
{
"source": "{{ container_config_directory }}/dashboards/",
"dest": "/var/lib/grafana/dashboards",
"owner": "grafana",
"perm": "0755",
"optional": true
} }
], ],
"permissions": [ "permissions": [

View File

@ -0,0 +1,11 @@
# # config file version
apiVersion: 1
providers:
- name: 'default'
orgId: 1
folder: ''
folderUid: ''
type: file
options:
path: /var/lib/grafana/dashboards

View File

@ -0,0 +1,46 @@
.. _grafana-guide:
=======
Grafana
=======
Overview
~~~~~~~~
`Grafana <https://grafana.com>`_ is open and composable observability and
data visualization platform. Visualize metrics, logs, and traces from
multiple sources like Prometheus, Loki, Elasticsearch, InfluxDB,
Postgres and many more..
Preparation and deployment
~~~~~~~~~~~~~~~~~~~~~~~~~~
To enable Grafana, modify the configuration file ``/etc/kolla/globals.yml``
and change the following:
.. code-block:: yaml
enable_grafana: "yes"
If you would like to set up Prometheus as a data source additionally set:
.. code-block:: yaml
enable_prometheus: "yes"
Please follow :doc:`Prometheus Guide <prometheus-guide>` for more information
Custom Dashboards Provisioning
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Kolla Ansible sets Custom Dashboards Provisioning using `Dashboard provider <https://grafana.com/docs/grafana/latest/administration/provisioning/#dashboards>`_.
Dashboard's JSON files should be placed into
``{{ node_custom_config }}/grafana/dashboards/`` folder.
Dashboards will be imported to Grafana dashboards General Folder.
Grafana provisioner config can be altered by placing ``provisioning.yaml`` to
``{{ node_custom_config }}/grafana/`` folder.
For other settings follow configuration reference:
`Dashboard provider configuration <https://grafana.com/docs/grafana/latest/administration/provisioning/#dashboards>`_.

View File

@ -9,6 +9,7 @@ logging and monitoring services available in kolla.
:maxdepth: 1 :maxdepth: 1
central-logging-guide central-logging-guide
grafana-guide
influxdb-guide influxdb-guide
kafka-guide kafka-guide
monasca-guide monasca-guide

View File

@ -0,0 +1,6 @@
---
features:
- |
Adds support to import custom ``grafana`` dashboards. Dashboard's JSON
files should be placed into "{{ node_custom_config }}/grafana/dashboards/"
folder.