Monitoring your Kubernetes cluster is important to be able to see your cluster's health. By monitoring your cluster, you can see stats such as such as CPU, memory, and disk usage. Monitoring is supported for both Linux as well as Windows nodes in your cluster.
There are five main options to monitor your cluster:
- Kubectl
- Azure Monitor for containers
- Kubernetes dashboard
- Monitoring extension
- Grafana and Influx DB
- Heapster REST API
Monitoring your cluster in Kubernetes is powered by a component called Heapster. Heapster is a pod that is responsible for aggregating monitoring data from across all the nodes and pods in your cluster. Heapster is necessary for viewing monitoring data in the Kubernetes dashboard as well as in Grafana. Heapster comes preinstalled on aks-engine
deployments. To ensure that Heapster is set up in your cluster and is running:
- Ensure you have set up a working kubernetes cluster and are able to use kubectl
- Run
kubectl get pods --namespace=kube-system
$ kubectl get pods --namespace=kube-system
NAME READY STATUS RESTARTS AGE
Heapster-4081560158-cnhn7 2/2 Running 0 20d
kube-addon-manager-k8s-master-13181513-0 1/1 Running 0 20d
kube-apiserver-k8s-master-13181513-0 1/1 Running 0 20d
kube-controller-manager-k8s-master-13181513-0 1/1 Running 0 20d
kube-dns-v20-3119293658-pnqqs 3/3 Running 0 20d
kube-dns-v20-3119293658-qbbjw 3/3 Running 0 20d
kube-proxy-f41qb 1/1 Running 0 20d
kube-scheduler-k8s-master-13181513-0 1/1 Running 0 20d
kubernetes-dashboard-2957563879-3h8gf 1/1 Running 0 20d
tiller-deploy-1318497129-wb74v 1/1 Running 0 20d
- Ensure you see Heapster listed and it is in a
Running
state.
The easiest way to see basic node metrics is by using kubectl. The kubectl top
command communicates with Heapster to get the latest node metrics and displays them in your terminal.
- To get node metrics:
kubectl top node
azureuser@k8s-master-95363663-0:~$ kubectl top node
NAME CPU(cores) CPU% MEMORY(bytes) MEMORY%
k8s-agentpool1-95363663-0 49m 2% 1298Mi 18%
k8s-master-95363663-0 105m 5% 1317Mi 19%
- To get pod metrics:
kubectl top pod
azureuser@k8s-master-95363663-0:~$ kubectl top pod
NAME CPU(cores) MEMORY(bytes)
somePod 0m 11Mi
Azure Monitor for containers is a feature designed to monitor the performance of container workloads deployed to AKS Engine (formerly known as ACS-Engine) cluster(s) hosted on Azure. Monitoring your containers is critical, especially when you're running a production cluster, at scale, with multiple applications.
Azure Monitor for containers gives you performance visibility by collecting memory and processor metrics from controllers, nodes, and containers that are available in Kubernetes through the Metrics API. Container logs are also collected. After you enable monitoring from Kubernetes clusters, these metrics and logs are automatically collected for you through a containerized version of the Log Analytics agent for Linux and stored in your Log Analytics workspace.
Azure Monitor for containers for AKS Engine cluster(s) can be configured through following options
Note: If more than one AKS Engine cluster planned to configure to the same Azure Log Analytics Workspace then recommend option is to use Helm chart (i.e. option #1 above)
Navigate to azmon-containers to view the health, metrics and logs of AKS-engine cluster(s).
For more details on how to use the product, see Azure Monitor for containers
Refer to azuremonitor-containers-aks-engine for the supported matrix, troubleshooting and supportability etc.
If you have any questions or feedback regarding the monitoring of your AKS Engine (or ACS-Engine) cluster(s), please reach us out through this email.
The Kubernetes dashboard is an easy way to visualize your cluster metrics. The Kubernetes dashboard displays all the metrics that are collected by the Heapster. The dashboard comes preinstalled on your cluster. To access the dashboard:
- On Linux, run
kubectl proxy
. This will allow you to access the dashboard athttp://localhost:8001/ui
- If you are using Windows and sshing into the master to use kubectl, you will need to set up remote port forwarding from port 8001 on the master to your host in order to use
kubectl proxy
. To do this, under PUTTY > Connection > SSH > Tunnels, create a new forwarded port (source local port 8001 to destination 127.0.0.1:8001).
- If you are using Windows and sshing into the master to use kubectl, you will need to set up remote port forwarding from port 8001 on the master to your host in order to use
Once you have opened the UI, you can explore node stats (CPU, Memory, etc...) under the nodes section on the left menu. You can also see pod level metrics under the pods section, and even drill into a specific container in a given pod.
A quick way to scaffold out cloud-native and open source monitoring components is to use the aks-engine monitoring extension. For details on how to use the monitoring extension, please refer to the extension documentation. By embedding the extension in your apimodel, the extension will do much of the work to create a monitoring solution in your cluster, which includes the following:
- cAdvisor daemon set to publish container metrics
- Prometheus for metrics collection and storage
- Grafana for dashboard and visualizations
The extension wires up these components together. Post-deplyoment of the Kubernetes cluster, you just have to retrieve Grafana admin password (Kubernetes secret) and target your browser to the Grafana endpoint. There is already a pre-loaded Kubernetes cluster monitoring dashboard, so out-of-the-box you will have meaningful monitoring points with the extensibility that Prometheus and Grafana offer you.
Another option to see stats is via Grafana and Influx DB. Grafana is a powerful dashboarding tool that can be used to visualize all types of data from various sources. InfluxDB is a database that is used to store time series data. Heapster is responsible for aggregating metrics across your cluster and ingesting them into InfluxDB. Then Grafana uses InfluxDB as it's datasource to visualize metrics.
To set up Grafana, we will need to deploy Grafana and InfluxDB. We will also need to configure Heapster to use InfluxDB as its storage backend.
-
wget https://raw.githubusercontent.com/kubernetes/heapster/release-1.5/deploy/kube-config/influxdb/influxdb.yaml
-
wget https://raw.githubusercontent.com/kubernetes/heapster/release-1.5/deploy/kube-config/influxdb/grafana.yaml
-
kubectl create -f influxdb.yaml
-
kubectl create -f grafana.yaml
-
kubectl get pods --namespace=kube-system
Ensure that Heapster, Grafana and InfluxDB are in theRunning
state -
kubectl edit deployment/heapster --namespace=kube-system
We need to configure Heapster to use InfluxDB as the the data store. To do that under the spec > containers > command property change the command field from:
- command: - /heapster - --source=kubernetes.summary_api:""
to this:
- command: - /heapster - --source=kubernetes.summary_api:"" - --sink=influxdb:http://monitoring-influxdb.kube-system.svc:8086
-
Save and exit from your editor to change the deployment. Now, Heapster will restart the pods and be configured to use InfluxDB. To ensure everything is ok, check the Heapster logs:
-
getHeapster() { kubectl get pods -o go-template --template '{{range .items}}{{.metadata.name}}{{"\n"}}{{end}}' --namespace=kube-system | grep -i heapster; }
-
kubectl logs $(getHeapster) --namespace=kube-system -c heapster
Look at the logs of heapster to ensure it started up correctly. You should see something like this if everything is ok:
azureuser@k8s-master-95363663-0:~/Heapster$ kubectl logs $(getHeapster) --namespace=kube-system -c heapster
I0830 22:30:57.671954 1 Heapster.go:72] /heapster --source=kubernetes:https://kubernetes.default --sink=influxdb:http://monitoring-influxdb.kube-system.svc:8086
I0830 22:30:57.671989 1 Heapster.go:73] Heapster version v1.3.0
I0830 22:30:57.672149 1 configs.go:61] Using Kubernetes client with master "https://kubernetes.default" and version v1
I0830 22:30:57.672166 1 configs.go:62] Using kubelet port 10255
I0830 22:30:57.747473 1 influxdb.go:252] created influxdb sink with options: host:monitoring-influxdb.kube-system.svc:8086 user:root db:k8s
I0830 22:30:57.747548 1 Heapster.go:196] Starting with InfluxDB Sink
I0830 22:30:57.747573 1 Heapster.go:196] Starting with Metric Sink
I0830 22:30:57.759987 1 Heapster.go:106] Starting heapster on port 8082
I0830 22:31:05.106039 1 influxdb.go:215] Created database "k8s" on influxDB server at "monitoring-influxdb.kube-system.svc:8086"
If everything looks ok and Grafana and Influx DB were able to start up, you can now access them! To do that:
-
Run
kubectl proxy
.- If you are using Windows and sshing into the master to use kubectl, you will need to set up remote port forwarding from port 8001 on the master to your host in order to use
kubectl proxy
. To do this, under Putty > Connection > SSH > Tunnels, create a new forwarded port (source local port 8001 to destination 127.0.0.1:8001).
- If you are using Windows and sshing into the master to use kubectl, you will need to set up remote port forwarding from port 8001 on the master to your host in order to use
-
To see cluster stats:
http://localhost:8001/api/v1/namespaces/kube-system/services/monitoring-grafana/proxy/dashboard/db/cluster
-
To see pod stats:
http://localhost:8001/api/v1/namespaces/kube-system/services/monitoring-grafana/proxy/dashboard/db/pods
Heapster exposes a REST API that can be used to programmatically obtain cluster metrics. The full documentation for the REST API is here. The REST API can be useful if you need to obtain metrics in your custom application or integrate metrics in an existing system.
Here are a few examples on how to use the REST API.
- Run
kubectl proxy
curl http://localhost:8001/api/v1/namespaces/kube-system/services/heapster/proxy/api/v1/model/nodes
[
"k8s-agentpool1-95363663-0",
"k8s-master-95363663-0"
]
curl http://localhost:8001/api/v1/namespaces/kube-system/services/heapster/proxy/api/v1/model/nodes/k8s-master-95363663-0/metrics
[
"cpu/usage",
"network/rx_errors",
"memory/major_page_faults",
"memory/page_faults_rate",
"cpu/node_allocatable",
...
]
curl http://localhost:8001/api/v1/namespaces/kube-system/services/heapster/proxy/api/v1/model/nodes/k8s-master-95363663-0/metrics/cpu/usage
{
metrics: [
{
timestamp: "2017-08-31T00:08:00Z",
value: 1040133457832
},
{
timestamp: "2017-08-31T00:09:00Z",
value: 1046556719483
},
{
timestamp: "2017-08-31T00:10:00Z",
value: 1052835238099
}
],
latestTimestamp: "2017-08-31T00:10:00Z"
}
For more details take a look at the Heapster model documentation.