Kubernetes z-pages

特性状态: Kubernetes v1.32 [alpha]

Kubernetes 的核心组件可以暴露一系列 z-endpoints,以便用户更轻松地调试他们的集群及其组件。 这些端点仅用于人工检查,以获取组件二进制文件的实时调试信息。请不要自动抓取这些端点返回的数据; 在 Kubernetes 1.32 中,这些是 Alpha 特性,响应格式可能会在未来版本中发生变化。

z-pages

Kubernetes v1.32 允许你启用 z-pages 来帮助排查其核心控制平面组件的问题。 这些特殊的调试端点提供与正在运行的组件有关的内部信息。对于 Kubernetes 1.32, 这些组件提供以下端点(当启用 z-pages 后):

statusz

使用 ComponentStatusz 特性门控启用后, /statusz 端点显示有关组件的高级信息,例如其 Kubernetes 版本、仿真版本、启动时间等。

来自 API 服务器的 /statusz 响应类似于:

  1. kube-apiserver statusz
  2. Warning: This endpoint is not meant to be machine parseable, has no formatting compatibility guarantees and is for debugging purposes only.
  3. Started: Wed Oct 16 21:03:43 UTC 2024
  4. Up: 0 hr 00 min 16 sec
  5. Go version: go1.23.2
  6. Binary version: 1.32.0-alpha.0.1484+5eeac4f21a491b-dirty
  7. Emulation version: 1.32.0-alpha.0.1484

flagz

使用 ComponentFlagz 特性门控启用后, /flagz 端点为你显示用于启动某组件的命令行参数。

API 服务器的 /flagz 数据看起来类似于:

  1. kube-apiserver flags
  2. Warning: This endpoint is not meant to be machine parseable, has no formatting compatibility guarantees and is for debugging purposes only.
  3. advertise-address=192.168.8.2
  4. contention-profiling=false
  5. enable-priority-and-fairness=true
  6. profiling=true
  7. authorization-mode=[Node,RBAC]
  8. authorization-webhook-cache-authorized-ttl=5m0s
  9. authorization-webhook-cache-unauthorized-ttl=30s
  10. authorization-webhook-version=v1beta1
  11. default-watch-cache-size=100