Skip to content

Latest commit

 

History

History
113 lines (81 loc) · 5.35 KB

custom-metrics.md

File metadata and controls

113 lines (81 loc) · 5.35 KB

Custom Metrics in Kubernetes

Preface

Our aim is to create a mechanism in Kubernetes that will allow pods to expose custom system metrics, collect them, and make them accessible. Custom metrics are needed by:

  • horizontal pod autoscaler, for autoscaling the number of pods based on them;
  • scheduler, for using them in a sophisticated scheduling algorithm.

High level goals for our solution for version 1.2 are:

  • easy to use (it should be easy to export custom metric from user's application),
  • works for most application (it should be easy to configure monitoring for third-party applications),
  • performance & scalability (the largest supported cluster should be able to handle ~5 custom metrics per pod with reporting latency ~30 seconds).

For version 1.2, we are not going to address the following issues (non-goals):

  • security of access to custom metrics,
  • general monitoring of application health by a user (out of the heapster scope, see #665).

Design

For the Kubernetes version 1.2, we plan to implement aggregation of pod custom metrics in Prometheus format by pull.

Each pod, to expose custom metrics, will expose a set of Prometheus endpoints. (For version 1.2, we assume that custom metrics are not private information and they are accessible by everyone. In future, we may restrict it by making the endpoints accessible only by kubelet/cAdvisor). CAdvisor will collect metrics from such endpoints of all pods on each node by pulling, and expose them to Heapster. Heapster will:

  • collect custom metrics from all CAdvisors in the cluster, together with pulling system metrics (for version 1.2: we assume pooling period of ~30 seconds),
  • store them in a metrics backend (influxDB, Prometheus, Hawkular, GCM, …),
  • expose the latest snapshot of custom metrics for queries (by HPA/scheduler/…) using model API.

User can easily expose Prometheus metrics for her own application by using Prometheus client library. To monitor third-party applications, Prometheus exporters run as side-cars containers may be used.

For version 1.2, to prevent a huge number of metrics negatively affect the system performance, the number of metrics that can be exposed by each pod will be limited to the configurable value (default: 5). In future, we will need a way to cap the number of exposed metrics per pod, one of possible solutions is using LimtRanger admission control plugin.

In future versions (later than 1.2), we want to extend our solution by:

  • accepting pod metrics exposed in different formats than Prometheus (collecting of the different formats will need to be supported by cAdvisor),
  • support push metrics by exposing push API on heapster (e.g. in StatsD format) or on a local node collector (if heapster performance is insufficient),
  • support metrics not associated with an individual pod.

API

For Kubernetes 1.2, defining pod Prometheus endpoints will be done using annotations. Later, when we are sure that our API is correct and stable, we will make it a part of PodSpec.

We will add a new optional pod annotation with the following key: metrics.alpha.kubernetes.io/custom-endpoints. It will contain a string-value in JSON format. The value will be a list of tuples defining ports, paths and API (currently, we will support only Prometheus API, this will be also the default value if format is empty) of metrics endpoints exposed by the pod, and names of metrics which should be taken from the endpoint (obligatory, no more than the configurable limit).

The annotation will be interpreted by kubelet during pod creation. It will not be possible to add/delete/edit it during the life time of a pod: such operations will be rejected.

For example, the following configuration:

"metrics.alpha.kubernetes.io/custom-endpoints" = [
	{
		"api": "prometheus",
		"path": "/status",
		"port": "8080",
		"names": ["qps", "activeConnections"]
	},
	{
		"path": "/metrics",
		"port": "9090"
		"names": ["myMetric"]
	}
]

will expose metrics with names qps and activeConnections from localhost:8080/status and metric myMetric from localhost:9090/metrics. Please note that both endpoints are in Prometheus format.

Implementation notes

  1. Kubelet will parse value of metrics.alpha.kubernetes.io/custom-endpoints annotation for pods. In case of error, pod will not be started (will be marked as failed) and kubelet will generate FailedToCreateContainer event with appropriate message (we will not introduce any new event type, as types of events are considered a part of kubelet API and we do not want to change it).

  2. Kubelet will use application metrics in CAdvisor for implementation:

    • It will create a configuration file for CAdvisor based on the annotation,
    • It will mount this file as a part of a docker image to run,
    • It will set a docker label for the image to point CAdvisor to this file.

Analytics