Kubernetes Kapsule is fully integrated with Scaleway’s Observability Cockpit. You can monitor your cluster directly from the cluster’s dashboard, eliminating the need to set up your own monitoring solution. The following content is provided for informational purposes only.
Using Grafana and Loki to Manage Kubernetes Logs
- Grafana
- Loki
- Kubernetes
- logs
In this tutorial, you will learn how to use Loki and Grafana to collect your Kubernetes logs on a Kapsule cluster.
Loki is a log aggregation system inspired by Prometheus. It is easy to operate, as it does not index the content of the Kubernetes logs but sets labels for log streams. Your metadata (object labels) can be used in Loki for scraping Kubernetes logs. If you use Grafana for metrics, Loki will allow you to have a single point of management for both logging and monitoring.
Before you start
To complete the actions presented below, you must have:
- A Scaleway account logged into the console
- Owner status or IAM permissions allowing you to perform actions in the intended Organization
- Created a Kapsule cluster
- Configured kubectl on your machine
- Installed
helm
(version 3.2+), the Kubernetes packet manager, on your local machine
- Add the Grafana repository to Helm and update it.
helm repo add grafana https://grafana.github.io/helm-chartshelm repo update
- Install Loki in a Kubernetes dedicated namespace named
loki-stack
with persistence enabled:
helm install loki grafana/loki-distributed \--create-namespace \--namespace loki-stack \--set storage_config.aws.s3.force_path_style=true \--set storage_config.aws.s3.endpoint=s3.scaleway.com \--set persistence.enabled=true,persistence.size=100Gi
- Install Promtail for log collection:
helm install promtail grafana/promtail \--namespace loki-stack \--set "config.clients[0].url=http://loki:3100/loki/api/v1/push"
- Install Grafana with persistence enabled:
helm install grafana grafana/grafana \--namespace loki-stack \--set persistence.enabled=true,persistence.size=10Gi
- Check if the pods are running correctly:
kubectl get pods -n loki-stack
- Get the admin password for Grafana:
kubectl get secret --namespace loki-stack grafana -o jsonpath="{.data.admin-password}" | base64 --decode
- Configure port-forwarding to access Grafana from your browser:
kubectl port-forward --namespace loki-stack service/grafana 3000:80
-
Access
http://localhost:3000
in your browser. Use the admin username and password retrieved earlier. -
Add Loki as a data source:
- Go to Configuration > Data Sources.
- Click + Add Data Source and select Loki.
- Enter the Loki URL:
http://loki.loki-stack:3100
.
- Verify the logs using Grafana’s Explore tab.
retention:period: 30ddeletes_enabled: true
You now have Loki, Promtail, and Grafana running in your Kubernetes cluster. Logs from your pods are stored in Loki and can be queried in Grafana. Refer to theGrafana documentation for advanced queries and visualization options.