KubeStash Grafana Dashboard
Grafana provides an elegant graphical user interface to visualize data. You can create a beautiful dashboard easily with a meaningful representation of your Prometheus metrics.
We provide a pre-built Grafana dashboard to our KubeStash users. In this guide, we are going to show you how you can import this dashboard from your Grafana UI.
Before You Begin
- At first, you need to setup a Prometheus monitoring stack in your cluster. Please, follow the Prometheus Operator guide to setup your monitoring stack if you haven’t done already.
- Then, install KubeStash with monitoring enabled. Please, follow this guide if you haven’t done already.
- You must have
kubestash_dashboard.json
file. Please, contact us to get the dashboard JSON file.
Install Panopticon
KubeStash Grafana dashboard depends on our another product called Panopticon. It is a Kubernetes state metric exporter similar to kube-state-metrics but generic for all Kubernetes resources including CRDs. In this section, we are going to show the installation procedure for Panopticon.
Issue License:
Like other AppsCode products, Panopticon also need a license to run. You can grab a 30 days trial license for Panopticon from here.
If you already have a license for KubeDB or KubeStash, you do not need to issue a new license for Panopticon. Your existing KubeDB or KubeStash license will work with Panopticon.
Install Panopticon:
Now, install Panopticon using the following commands:
$ helm repo add appscode https://charts.appscode.com/stable/
$ helm repo update
$ helm install panopticon appscode/panopticon -n kubeops \
--create-namespace \
--set monitoring.enabled=true \
--set monitoring.agent=prometheus.io/operator \
--set monitoring.serviceMonitor.labels.release=prometheus-stack \
--set-file license=/path/to/license-file.txt
Make sure to use the appropriate label in monitoring.serviceMonitor.labels
field according to your setup. This label is used by the Prometheus server to select the desired ServiceMonitor.
Import KubeStash Garafana Dashboard
At first, let’s port-forward the respective service for the Grafana dashboard so that we can access it through our browser locally.
$ kubectl port-forward -n monitoring service/prometheus-stack-grafana 3000:80
Forwarding from 127.0.0.1:3000 -> 3000
Forwarding from [::1]:3000 -> 3000
Now, go to http://localhost:3000 in your browser and login to your Grafana UI. If you followed the Prometheus Operator guide to deploy your Prometheus stack, then the default username and password should be admin
, and prom-operator
respectively.
Then, on the Grafana UI, click the +
icon from the left sidebar and then click on Import
button as below,
data:image/s3,"s3://crabby-images/9088e/9088efab0887fb0a291b515a6cdf64237d5dff4f" alt="Import KubeStash Grafana Dashboard: Step 1"
Then, on the import UI, you can either upload the kubestash_dashboard.json
file by clicking the Upload JSON file
button or you can paste the content of the JSON file in the text area labeled as Import via panel json
.
data:image/s3,"s3://crabby-images/66fd0/66fd071c8a8e49a8a8cdf7ea0a750b2b9105f712" alt="Import KubeStash Grafana Dashboard: Step 2"
If you followed the instruction properly, you should see the KubeStash Grafana dashboard in your Grafana UI.
data:image/s3,"s3://crabby-images/95c52/95c52601c9f97a7d082aa2c04685afeb31117684" alt="KubeStash Grafana Dashboard"
If your cluster does not have any backup configured, you may see the dashboard panels are empty. Nothing to worry about here. Just, run some backups and your dashboard should be populated automatically.