From d99aefe27628d01fcc6fb764e3bca4203742a92d Mon Sep 17 00:00:00 2001 From: Deepak Jain <deepakj@hotstar.com> Date: Mon, 14 Oct 2019 14:29:11 +0530 Subject: [PATCH] CLOUD-3031| Deepak Jain| adding example file --- ...ng-prometheus-rules-and-grafana-dashboards.md | 1 + ...ditional-rendered-dashboard-example-2.jsonnet | 16 ++++++++++++++++ 2 files changed, 17 insertions(+) create mode 100644 examples/grafana-additional-rendered-dashboard-example-2.jsonnet diff --git a/docs/developing-prometheus-rules-and-grafana-dashboards.md b/docs/developing-prometheus-rules-and-grafana-dashboards.md index d3fbd93e..974c3cc4 100644 --- a/docs/developing-prometheus-rules-and-grafana-dashboards.md +++ b/docs/developing-prometheus-rules-and-grafana-dashboards.md @@ -312,6 +312,7 @@ local kp = (import 'kube-prometheus/kube-prometheus.libsonnet') + { ``` Incase you have lots of json dashboard exported out from grafan UI the above approch is going to take lots of time. to improve performance we can use `rawGrafanaDashboards` field and provide it's value as json string by using importstr +[embedmd]:# (../examples/grafana-additional-rendered-dashboard-example-2.jsonnet) ```jsonnet local kp = (import 'kube-prometheus/kube-prometheus.libsonnet') + { _config+:: { diff --git a/examples/grafana-additional-rendered-dashboard-example-2.jsonnet b/examples/grafana-additional-rendered-dashboard-example-2.jsonnet new file mode 100644 index 00000000..391b0f02 --- /dev/null +++ b/examples/grafana-additional-rendered-dashboard-example-2.jsonnet @@ -0,0 +1,16 @@ +local kp = (import 'kube-prometheus/kube-prometheus.libsonnet') + { + _config+:: { + namespace: 'monitoring', + }, + rawGrafanaDashboards+:: { + 'my-dashboard.json': (importstr 'example-grafana-dashboard.json'), + }, +}; + +{ ['00namespace-' + name]: kp.kubePrometheus[name] for name in std.objectFields(kp.kubePrometheus) } + +{ ['0prometheus-operator-' + name]: kp.prometheusOperator[name] for name in std.objectFields(kp.prometheusOperator) } + +{ ['node-exporter-' + name]: kp.nodeExporter[name] for name in std.objectFields(kp.nodeExporter) } + +{ ['kube-state-metrics-' + name]: kp.kubeStateMetrics[name] for name in std.objectFields(kp.kubeStateMetrics) } + +{ ['alertmanager-' + name]: kp.alertmanager[name] for name in std.objectFields(kp.alertmanager) } + +{ ['prometheus-' + name]: kp.prometheus[name] for name in std.objectFields(kp.prometheus) } + +{ ['grafana-' + name]: kp.grafana[name] for name in std.objectFields(kp.grafana) } -- GitLab