This document describes how to install and manage Prow cluster monitoring that is available at https://monitoring.build.kyma-project.io
. This document also describes how to create and manage Grafana dashboards.
Install the following tools:
- Helm v2.11.0
- kubectl
Follow these steps:
-
Create a Slack channel and an Incoming Webhook for this channel. Copy the resulting Webhook URL.
-
Replace
{SLACK_URL}
in values.yaml with the Weebhook URL and{SLACK_CHANNEL}
with the channel name.
Follow these steps:
-
Make sure that kubectl points to the correct cluster.
gcloud container clusters get-credentials {clusterName} --zone={zoneName} --project={projectName}
-
Go to the
prow/cluster
directory. -
Download dependencies:
helm dependency build resources/monitoring
-
Install the monitoring chart:
helm install --name {releaseName} --namespace {namespaceName} resources/monitoring
-
Open the Grafana dashboard.
Grafana dashboard is available at
https://monitoring.build.kyma-project.io
. It can take some time till the dashboard is accessible.
By default, Grafana dashboards are visible for anonymous users with the read-only access. Only authenticated users are able to create and edit dashboards. To sign in to Grafana, follow this steps:
-
Get the password for the
admin
user from the cluster:kubectl -n {namespaceName} get secret {releaseName}-grafana -o jsonpath="{.data.admin-password}" | base64 -D
-
Go to
https://monitoring.build.kyma-project.io/login
. -
Provide credentials:
Login: admin Password: {The value from step 1}
To create or edit Grafana dashboards you must be signed in. The official Grafana documentation provides instructions on how to work with the dashboards. The main difference between the official guidelines and the the Kyma implementation of Grafana dashboards is the way in which you store them.
Follow these steps to save the dashboard:
-
Export the dashboard to a JSON format.
-
Save the JSON file under
prow/cluster/resources/monitoring/dashboards/
. -
Update the Grafana configuration on the cluster.
helm upgrade {releaseName} resources/monitoring --recreate-pods
NOTE:
--recreate-pods
is required because the Secret with the Grafana password is regenerated during the upgrade and it needs to be populated to Grafana.