如何升级 Kubernetes 节点的 cgroup 版本

💡 原文中文,约3800字,阅读约需10分钟。
📝

内容提要

cgroup v2 是 cgroup v1 的升级版,提供更统一的资源管理和隔离。Kubernetes 默认支持 cgroup v2,但实际使用依赖于宿主机内核。Ubuntu 20 默认使用 cgroup v1,而 Ubuntu 22 则使用 cgroup v2。升级 cgroup 版本需在内核 5.4 及以上进行配置。

🎯

关键要点

  • cgroup v2 是 cgroup v1 的升级版,提供更统一的资源管理和隔离。
  • Kubernetes 默认支持 cgroup v2,但实际使用依赖于宿主机内核。
  • Ubuntu 20 默认使用 cgroup v1,而 Ubuntu 22 默认使用 cgroup v2。
  • 升级 cgroup 版本需在内核 5.4 及以上进行配置。
  • cgroup v1 和 v2 的接口路径不同,需要兼容处理。
  • 可以通过 DaemonSet 查看全部节点上 Pod 的 cgroup 配置。
  • Ubuntu 20 和 22 的 Pod 显示了不同的 cgroup 版本。
  • 推荐在内核 5.4 及之后版本启用 cgroup v2。
  • 检查 cgroup 版本和内核版本的方法包括使用 stat 和 uname 命令。
  • 更新 GRUB 配置以启用 cgroup v2 需要重启系统。
  • Containerd 和 Kubelet 的配置需设置为使用 cgroup v2。
  • 低版本内核可能导致无法启用 cgroup v2,可能出现相关错误。
➡️

继续阅读