This document explains how to use the grafana-dashboard
and setup-tracing
make targets to install and configure observability tools.
Ensure the following tools are installed on your local machine:
- Kubernetes: A running Kubernetes cluster.
- kubectl: To manage the cluster.
- Helm: To install and manage Helm charts for Prometheus and Grafana.
You should also have access to the Kubernetes cluster's kubeconfig file (test-cluster-kubeconfig.yaml
), which will be used for running the make target.
Here’s a more detailed explanation of the steps for opting in to the metrics for the CSI driver. The commands involve first deleting the existing CSI driver and then reinstalling it with metrics enabled:
To enable the metrics collection for the Linode CSI driver, follow the steps below. These steps involve exporting a new Helm template with metrics enabled, deleting the current CSI driver release, and applying the newly generated configuration.
First, you need to generate a new Helm template for the Linode CSI driver with the enableMetrics
flag set to true
. You will also have to specify an address that isn't in use for the metrics server to run on. This ensures that the CSI driver is configured to expose its metrics.
helm template linode-csi-driver \
--set apiToken="${LINODE_API_TOKEN}" \
--set region="${REGION}" \
--set enableMetrics="${ENABLE_METRICS}" \
--set metricsPort="${METRICS_PORT}" \
helm-chart/csi-driver --namespace kube-system > csi.yaml
2. Delete the Existing Release of the CSI Driver (Needed only if the CSI driver is already installed on your cluster)
Before applying the new configuration, you need to delete the current release of the Linode CSI driver. This step is necessary because the default CSI driver installation does not have metrics enabled, and Helm doesn’t handle changes to some components gracefully without a clean reinstall.
kubectl delete -f csi.yaml --namespace kube-system
Once the old CSI driver installation is deleted, you can apply the newly generated template that includes the metrics configuration.
kubectl apply -f csi.yaml
If you haven’t already set up your Kubernetes cluster with the necessary CSI driver and Prometheus metrics services, you can do so by running the following command:
make mgmt-and-capl-cluster
This command creates a management cluster and CAPL (Cluster API for Linode) cluster, installs the Linode CSI driver, and applies the necessary configurations to expose the CSI metrics.
The grafana-dashboard
make target combines the installation of Prometheus, Grafana, and the dashboard configuration. It ensures that Prometheus is installed and connected to Grafana, and that a pre-configured dashboard is applied. To execute this setup, run:
make grafana-dashboard
This target combines three separate make targets:
install-prometheus
: Installs Prometheus using a Helm chart in themonitoring
namespace. Prometheus is configured to scrape metrics from the CSI driver and other services.install-grafana
: Installs Grafana using a Helm chart in themonitoring
namespace, with Prometheus as its data source.setup-dashboard
: Sets up a pre-configured Grafana dashboard by applying a ConfigMap containing the dashboard JSON (observability/metrics/dashboard.json
).
Sure! Here's a more concise, table-like version of the documentation for customizing the Grafana dashboard setup:
The grafana-dashboard
target installs Prometheus, Grafana, and applies the dashboard configuration. To run the setup:
make grafana-dashboard
You can customize various aspects of the setup by passing environment variables when running the make grafana-dashboard
command. Use the following variables:
Variable | Description | Example |
---|---|---|
DATA_RETENTION_PERIOD |
Sets the data retention period for Prometheus. | DATA_RETENTION_PERIOD=30d |
GRAFANA_USERNAME |
Sets the Grafana admin username. | GRAFANA_USERNAME=myadmin |
GRAFANA_PASSWORD |
Sets the Grafana admin password. | GRAFANA_PASSWORD=password |
To set a retention period of 30 days, and customize the Grafana admin credentials:
DATA_RETENTION_PERIOD=30d GRAFANA_USERNAME=user GRAFANA_PASSWORD=securepass make grafana-dashboard
These variables customize the respective make targets: install-prometheus
for Prometheus configuration and install-grafana
for Grafana configuration.
Once the setup is complete, you can access the Grafana dashboard through the configured LoadBalancer service. After the setup script runs, the external IP of the LoadBalancer is printed, and you can access Grafana by opening the following URL in your browser:
http://<LoadBalancer-EXTERNAL-IP>
Log in using the following credentials:
- Username:
admin
- Password:
admin
These credentials can be customized via environment variables in the install-monitoring-tools.sh
script if needed.
If you are using port forwarding instead of a LoadBalancer, and you wish to stop the forwarding, run:
kill <PID>
Replace <PID>
with the process ID provided by the script during the setup.
If you do not have access to the script output, run:
ps -ef | grep 'kubectl port-forward' | grep -v grep
This will give you details about the process and also the PID
.
-
Namespace: The default namespace for the observability tools is
monitoring
. You can modify this by passing the--namespace
flag or editing theinstall-monitoring-tools.sh
script and changing theNAMESPACE
variable. -
Grafana Dashboard Configuration: The default dashboard configuration is stored in
observability/metrics/dashboard.json
. To apply a different dashboard, replace the contents of this file before running themake grafana-dashboard
target. -
Prometheus Data Source: The default data source is Prometheus, as defined in the Helm chart configuration. If you wish to use a different data source, modify the
helm upgrade
command ininstall-monitoring-tools.sh
.
Installs Prometheus in the monitoring
namespace using a Helm chart. Prometheus scrapes metrics from the CSI driver and other services in the cluster.
make install-prometheus
Installs Grafana in the monitoring
namespace using a Helm chart. Prometheus is set as the data source for Grafana.
make install-grafana
Sets up the pre-configured Grafana dashboard by applying a ConfigMap containing the dashboard JSON. This ConfigMap is created from the observability/metrics/dashboard.json
file.
make setup-dashboard
This is a combined target that installs Prometheus, Grafana, and configures the Grafana dashboard. It runs the install-prometheus
, install-grafana
, and setup-dashboard
targets sequentially.
make grafana-dashboard
If you encounter issues during the installation process, check the logs and status of the Prometheus and Grafana pods:
kubectl get pods -n monitoring
kubectl logs <prometheus-pod-name> -n monitoring
kubectl logs <grafana-pod-name> -n monitoring
This setup provides a quick and easy way to enable observability using Grafana dashboards, ensuring that you have visibility into your Kubernetes cluster and CSI driver operations.
To enable the tracing for the Linode CSI driver, follow the steps below. These steps involve exporting a new Helm template with tracing enabled, deleting the current CSI driver release, and applying the newly generated configuration.
First, you need to generate a new Helm template for the Linode CSI driver with the enableTracing
flag set to true
. You will also have to specify an address that isn't in use for the otel server to run on. By default, the port is set to 4318
.
helm template linode-csi-driver \
--set apiToken="${LINODE_API_TOKEN}" \
--set region="${REGION}" \
--set enableTracing="true" \
--set tracingPort="4318" \
helm-chart/csi-driver --namespace kube-system > csi.yaml
2. Delete the Existing Release of the CSI Driver (Needed only if the CSI driver is already installed on your cluster)
Before applying the new configuration, you need to delete the current release of the Linode CSI driver. This step is necessary because the default CSI driver installation does not have tracing enabled, and Helm doesn’t handle changes to some components gracefully without a clean reinstall.
kubectl delete -f csi.yaml --namespace kube-system
Once the old CSI driver installation is deleted, you can apply the newly generated template that includes the tracing configuration.
kubectl apply -f csi.yaml
Now, that we have the configuration ready, we must install otel and jaeger to visualize the traces.
The make target setup-tracing
installs otel-collector
and jaeger
for visualizing the traces.
make setup-tracing
Once the setup is complete, you can access the jaeger dashboard through the configured LoadBalancer service. After the setup script runs, the external IP of the LoadBalancer is printed, and you can access Jaeger by opening the following URL in your browser:
http://<LoadBalancer-EXTERNAL-IP>:16686
In case you want to use Jaeger in a dev environment run the following port-forward command:
kubectl port-forward svc/jaeger-collector 16686:16686 -n kube-system
You can access jaeger now by opening the following URL in your browser:
http://localhost:16686
Note: If you have made changes to the port, ensure that you change them while running this command.