Kubernetes Metrics
This page lists the Kubernetes metrics that are collected when you deploy the collection solution described in sumologic-kubernetes-collection deployment guide.
Information about filtering and relabeling metrics, and how to send custom Prometheus metrics to Sumo Logic, can be found in Collecting Application Metrics.
Kube state metrics (kube-state-metrics)β
kube-state-metrics is a service that listens to the Kubernetes API server and generates metrics about the state of the objects, including deployments, nodes, and pods.
You can deploy kube-state-metrics using the Sumo Logic Kubernetes Collection Helm Chart.
You can use kube-state-metrics in managed Kubernetes environments, such as GKE, EKS, or AKS, or in a Kubernetes deployment you manage yourself.
kube-state-metrics metrics to collectβ
This section lists recommended metrics to collect. For information about all kube-state-metrics, and metric descriptions, see kube-state-metrics docs
- kube_daemonset_status_current_number_scheduled
- kube_daemonset_status_desired_number_scheduled
- kube_daemonset_status_number_misscheduled
- kube_daemonset_status_number_unavailable
- kube_deployment_spec_replicas
- kube_deployment_status_replicas_available
- kube_deployment_status_replicas_unavailable
- kube_node_info
- kube_node_status_allocatable
- kube_node_status_capacity
- kube_node_status_condition
- kube_statefulset_metadata_generation
- kube_statefulset_replicas
- kube_statefulset_status_observed_generation
- kube_statefulset_status_replicas
- kube_hpa_spec_max_replicas
- kube_hpa_spec_min_replicas
- kube_hpa_status_condition
- kube_hpa_status_current_replicas
- kube_hpa_status_desired_replicas
- kube_pod_container_info
- kube_pod_container_resource_limits
- kube_pod_container_resource_requests
- kube_pod_container_status_ready
- kube_pod_container_status_restarts_total
- kube_pod_container_status_terminated_reason
- kube_pod_container_status_waiting_reason
- kube_pod_status_phase
- kube_service_info
- kube_service_spec_external_ip
- kube_service_spec_type
- kube_service_status_load_balancer_ingress
View kube-state-metricsβ
Assuming that you have the Sumo Logic Kubernetes Collection Helm Chart installed in your cluster, run this command to start a proxy to the Kubernetes API server:
kubectl proxy
To view metrics, open your browser to:
http://127.0.0.1:8001/api/v1/namespaces/SUMOLOGIC_HELM_CHART_NAMESPACE/services/SUMOLOGIC_HELM_CHART_RELEASE_NAME-kube-state-metrics:8080/proxy/metrics
Where SUMOLOGIC_HELM_CHART_NAMESPACE
is the namespace where the Sumo Logic Kubernetes Collection Helm Chart is installed and
SUMOLOGIC_HELM_CHART_RELEASE_NAME
is the the release name of the Sumo Logic Kubernetes Collection Helm Chart in your cluster.
Controller Manager (kube-controller-manager) metricsβ
Controller manager metrics provide important insight into the performance and health of the controller manager.
Collection of controller manager metrics requires a service to be deployed to talk to controller manager. The Sumo Logic Kubernetes Collection Helm Chart creates this service.
You can collect kube-scheduler metrics in a Kubernetes deployment you manage yourself. You canβt collect kube-scheduler metrics in managed Kubernetes environments, such as GKE, EKS, or AKS.
kube-controller-manager metrics to collectβ
- cloudprovider_*_api_request_duration_seconds*
View kube-controller-manager metricsβ
To see kube-controller-manager metrics, run the curl command from a master node, using the appropriate certificates to pass the authentication process:
curl -k --cert /tmp/server.crt --key /tmp/server.key https://localhost:10257/metrics
Scheduler (kube-scheduler) metricsβ
Scheduler metrics provide information about for kubernetes scheduling.
Collection of scheduler metrics requires a service to be deployed to talk to scheduler. The Sumo Logic Kubernetes Collection Helm Chart creates this service.
You can collect kube-scheduler metrics in a Kubernetes deployment you manage yourself. You canβt collect kube-scheduler metrics in managed Kubernetes environments, such as GKE, EKS, or AKS.
kube-scheduler metrics to collectβ
- scheduler_e2e_scheduling_duration*
- scheduler_binding_duration*
- scheduler_scheduling_algorithm_duration*
View kube-scheduler metricsβ
To see kube-scheduler metrics, run the curl command from a master node, using the appropriate certificates to pass the authentication process:
curl -k --cert /tmp/server.crt --key /tmp/server.key https://localhost:10259/metrics
API Server (kube-apiserver) metricsβ
You can collect kube-apiserver metrics in managed Kubernetes environments, such as GKE, EKS, or AKS, or in a Kubernetes deployment you manage yourself.
kube-apiserver metrics to collectβ
- apiserver_request_count
- apiserver_request_latencies*
- etcd_request_cache_get_latencies_summary*
- etcd_request_cache_add_latencies_summary*
- etcd_helper_cache_hit_count
- etcd_helper_cache_miss_count
View apiserver metricsβ
Run this command to start a proxy to the Kubernetes API server:
kubectl proxy
To view metrics, open your browser to:
http://127.0.0.1:8001/metrics
Kubelet (kubelet) metricsβ
Kubelet acts as a bridge between the Kubernetes master and the Kubernetes nodes. It manages the pods and containers running on a machine.
You can collect kubelet in managed Kubernetes environments, such as GKE, EKS, or AKS, or in a Kubernetes deployment you manage yourself.
Collect from each node in the cluster.
Kubelet metrics to collectβ
- kubelet_docker_operations_errors
- kubelet_docker_operations_latency_microseconds*
- kubelet_running_container_count
- kubelet_running_pod_count
- kubelet_runtime_operations_latency_microseconds*
- etcd_helper_cache_hit_count
- etcd_helper_cache_miss_count
View kubelet metricsβ
Run this command to start a proxy to the Kubernetes API server:
kubectl proxy
To view metrics, open your browser to:
http://127.0.0.1:8001/api/v1/nodes/NODE_NAME/proxy/metrics
Where NODE_NAME
is the name of your node. For example:
http://127.0.0.1:8001/api/v1/nodes/ip-172-20-114-48.us-west-2.compute.internal/proxy/metrics
cAdvisor (kubelet) metricsβ
cAdvisor is an open source container resource usage and performance analysis agent.
You can collect cAdvisor metrics in managed Kubernetes environments, such as GKE, EKS, or AKS, or in a Kubernetes deployment you manage yourself.
cAdvisor metrics to collectβ
- container_cpu_usage_seconds_total
- container_fs_limit_bytes
- container_fs_usage_bytes
- container_memory_working_set_bytes
- container_cpu_cfs_throttled_seconds_total
- container_network_receive_bytes_total
- container_network_transmit_bytes_total
View cAdvisor metricsβ
Run this command to start a proxy to the Kubernetes API server:
kubectl proxy
To view metrics, open your browser to:
http://127.0.0.1:8001/api/v1/nodes/NODE_NAME/proxy/metrics/cadvisor
Where NODE_NAME
is the name of your node. For example:
http://127.0.0.1:8001/api/v1/nodes/ip-172-20-114-48.us-west-2.compute.internal/proxy/metrics/cadvisor
Node Exporter (node-exporter) metricsβ
You can collect Node Exporter metrics in managed Kubernetes environments, such as GKE, EKS, or AKS, or in a Kubernetes deployment you manage yourself.
For a full list of metrics scraped and forwarded by Sumo Logic Kubernetes, see this table. The table lists the metric name, source, and if it is forwarded.
Node Exporter metrics to collectβ
- node_cpu_seconds_total
- node_load1
- node_load5
- node_load15
- node_disk_io_time_weighted_seconds_total
- node_disk_io_time_seconds_total
- node_vmstat_pgpgin
- node_vmstat_pgpgout
- node_memory_MemFree_bytes
- node_memory_MemAvailable_bytes
- node_memory_Cached_bytes
- node_memory_Buffers_bytes
- node_memory_MemTotal_bytes
- node_network_receive_drop_total
- node_network_transmit_drop_total
- node_network_receive_bytes_total
- node_network_transmit_bytes_total
- node_filesystem_avail_bytes
- node_filesystem_size_bytes
- node_filesystem_files_free
- node_filesystem_files
View Node Exporter metricsβ
Assuming that you have the Sumo Logic Kubernetes Collection Helm Chart installed in your cluster, run this command to start a proxy to the Kubernetes API server:
kubectl proxy
To view metrics, open your browser to:
http://127.0.0.1:8001/api/v1/namespaces/SUMOLOGIC_HELM_CHART_NAMESPACE/services/SUMOLOGIC_HELM_CHART_RELEASE_NAME-prometheus-node-exporter:9100/proxy/metrics
Where SUMOLOGIC_HELM_CHART_NAMESPACE
is the namespace where the Sumo Logic Kubernetes Collection Helm Chart is installed and
SUMOLOGIC_HELM_CHART_RELEASE_NAME
is the the release name of the Sumo Logic Kubernetes Collection Helm Chart in your cluster.