Persistent Grafana Dashboards
To allow the Grafana dashboard to persist after the Grafana instance restarts, add the dashboard configuration JSON into a ConfigMap. ConfigMaps also allow the dashboards to be deployed with a GitOps or CD based approach. This allows the dashboard to be put under version control.
Creating a Persistent Grafana Dashboard
Prerequisites:
|
1. Get the JSON model of the dashboard that you want to persist
To create a persistent dashboard, you will need to get the JSON model of the dashboard you want to persist. You can use a premade dashboard or build your own.
To use a premade dashboard, go to https://grafana.com/grafana/dashboards, open up its detail page, and click on the Download JSON button to get the JSON model for the next step.
To use your own dashboard:
-
Click on the link to open Grafana. On the cluster detail page, click Monitoring.
-
Log in to Grafana. Note: The default Admin username and password for the Grafana instance is
admin/prom-operator
. Alternative credentials can also be supplied on deploying or upgrading the chart.Regardless of who has the password, in order to access the Grafana instance, you still need at least the Manage Services or View Monitoring permissions in the project that Rancher Monitoring is deployed into. Alternative credentials can also be supplied on deploying or upgrading the chart.
-
Create a dashboard using Grafana’s UI. Once complete, go to the dashboard’s settings by clicking on the gear icon in the top navigation menu. In the left navigation menu, click JSON Model.
-
Copy the JSON data structure that appears.
2. Create a ConfigMap using the Grafana JSON model
Create a ConfigMap in the namespace that contains your Grafana Dashboards (e.g. cattle-dashboards
by default).
The ConfigMap should look like this:
apiVersion: v1
kind: ConfigMap
metadata:
labels:
grafana_dashboard: "1"
name: <dashboard-name>
namespace: cattle-dashboards # Change if using a non-default namespace
data:
<dashboard-name>.json: |-
<copied-json>
By default, Grafana is configured to watch all ConfigMaps with the grafana_dashboard
label within the cattle-dashboards
namespace.
To specify that you would like Grafana to watch for ConfigMaps across all namespaces, refer to this section.
To create the ConfigMap through the Rancher UI, first make sure that you are currently logged in to the Grafana UI, to ensure that dashboards import without encountering permissions issues. Then, return to the Rancher UI and perform the following steps:
-
In the upper left corner, click ☰ > Cluster Management.
-
On the Clusters page, go to the cluster where you want to see the visualizations and click Explore.
-
Click menu:More Resources[Core > ConfigMaps].
-
Click Create.
-
On the Data tab, set up the key-value pairs similar to the example above. When entering the value for
<dashboard-name>.json
, click Read from File to upload the JSON data model as the value. -
On the Labels & Annotations tab, click Add Label and enter
grafana_dashboard
as the key, and1
as the value. -
Click Create.
Result: After the ConfigMap is created, it should show up on the Grafana UI and be persisted even if the Grafana pod is restarted.
The actual key-value pair may differ if you have modified the Helm chart to watch a different dashboard label and value. |
Dashboards that are persisted using ConfigMaps cannot be deleted or edited from the Grafana UI.
If you attempt to delete the dashboard in the Grafana UI, you will see the error message "Dashboard cannot be deleted because it was provisioned." To delete the dashboard, you will need to delete the ConfigMap.
Configuring Namespaces for the Grafana Dashboard ConfigMap
To specify that you would like Grafana to watch for ConfigMaps across all namespaces, set this value in the rancher-monitoring
Helm chart:
grafana.sidecar.dashboards.searchNamespace=ALL
Note that the RBAC roles exposed by the Monitoring chart to add Grafana Dashboards are still restricted to giving permissions for users to add dashboards in the namespace defined in grafana.dashboards.namespace
, which defaults to cattle-dashboards
.