kube-controller-manager组件监控指标及大盘使用说明

kube-controller-manager是管理多种Kubernetes控制器的控制面组件,例如负责节点管理的Node Controller、管理有状态应用的控制器StatefulSet Controller、处理无状态应用的Deployment Controller等。本文介绍kube-controller-manager组件的指标清单和对应大盘的使用指导。

相关概念

Workqueue

展开查看Workqueue术语说明

kube-controller-manager管理的Controller,例如Node Controller、StatefulSet Controller、Deployment Controller等,通常通过工作队列Workqueue机制来安全、并发地处理资源对象的更新。每当有新的事件发生时(例如Pod的创建、更新、删除等),相应的Controller会收到事件通知,将关联的资源标识符(例如Pod的名称、命名空间等)放入Workqueue中。Controller的工作循环会不断从Workqueue中取出这些资源标识符,并执行相应的逻辑来处理资源。

使用前须知

操作入口

请参见查看集群控制面组件监控大盘

指标清单

指标是组件对外透出状态和参数的方式之一,kube-controller-manager组件使用的指标清单如下。

指标

类型

说明

workqueue_adds_total

Counter

Workqueue处理的新增事件(Adds)数量。

workqueue_depth

Gauge

Workqueue当前队列深度。如果队列深度长时间保持在较高水平,表明Controller不能及时处理队列中的任务,导致任务堆积。

workqueue_queue_duration_seconds_bucket

Histogram

任务在Workqueue中存在的时长。Bucket阈值为{10-8, 10-7, 10-6, 10-5, 10-4, 10-3, 10-2, 10-1, 1, 10}。单位:秒。

memory_utilization_byte

Gauge

内存使用量。单位:字节(Byte)。

cpu_utilization_core

Gauge

CPU使用量。单位:核(Core)。

rest_client_requests_total

Counter

从状态值(Status Code)、方法(Method)和主机(Host)维度分析HTTP请求次数。

rest_client_request_duration_seconds_bucket

Histogram

从方法(Verb)和URL维度分析HTTP请求时延。

说明

如下资源使用率指标已废弃,请及时去除依赖该指标的告警和监控。

  • cpu_utilization_ratio:CPU使用率。

  • memory_utilization_ratio:内存使用率。

大盘使用指导

您可以配置大盘观测请求的分位数quantile和PromQL的采样时长interval。大盘基于组件指标和相关PromQL绘制,大盘的可观测性展示和功能解析如下。

Workqueue

可观测性展示kcm1

功能解析

名称

PromQL

说明

Workqueue入队速率

sum(rate(workqueue_adds_total{job="ack-kube-controller-manager"}[$interval])) by (name)

Workqueue在单位时间内新增事件(Adds)的数量。

Workqueue深度

sum(rate(workqueue_depth{job="ack-kube-controller-manager"}[$interval])) by (name)

Workqueue深度在单位时间内的变化。

Workqueue处理时延

histogram_quantile($quantile, sum(rate(workqueue_queue_duration_seconds_bucket{job="ack-kube-controller-manager"}[5m])) by (name, le))

事件在Workqueue中存在的时长。

资源

可观测性展示kcm2

功能解析

大盘名称

PromQL

说明

内存使用量

memory_utilization_byte{container="kube-controller-manager"}

内存使用量。单位:字节。

CPU使用量

cpu_utilization_core{container="kube-controller-manager"}*1000

CPU使用量。单位:毫核。

Kube API

可观测性展示kcm3

功能解析

大盘名称

PromQL

说明

Kube API请求QPS

  • sum(rate(rest_client_requests_total{job="ack-kube-controller-manager",code=~"2.."}[$interval])) by (method,code)

  • sum(rate(rest_client_requests_total{job="ack-cloud-controller-manager",code=~"3.."}[$interval])) by (method,code)

  • sum(rate(rest_client_requests_total{job="ack-cloud-controller-manager",code=~"4.."}[$interval])) by (method,code)

  • sum(rate(rest_client_requests_total{job="ack-cloud-controller-manager",code=~"5.."}[$interval])) by (method,code)

kube-controller-managerkube-apiserver发起的HTTP请求,从方法(Method)和返回值(Code)维度分析。

Kube API请求时延

histogram_quantile($quantile, sum(rate(rest_client_request_duration_seconds_bucket{job="ack-kube-controller-manager"}[$interval])) by (verb,url,le))

kube-controller-managerkube-apiserver发起的HTTP请求时延,从方法(Verb)和请求URL维度进行分析。

相关文档

关于其他集群控制面组件监控的指标详情、大盘使用指引和常见指标异常说明,请参见kube-apiserver组件监控指标说明etcd组件监控指标说明kube-scheduler组件监控指标说明cloud-controller-manager组件监控指标说明