如何升级 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,可能出现相关错误。

延伸问答

cgroup v2 和 cgroup v1 有什么区别?

cgroup v2 提供更统一的资源管理和隔离,接口路径也不同,需要兼容处理。

如何检查当前系统使用的 cgroup 版本?

可以使用命令 'stat -fc %T /sys/fs/cgroup/' 来查看 cgroup 版本。

在 Ubuntu 20 和 22 中,默认的 cgroup 版本是什么?

Ubuntu 20 默认使用 cgroup v1,而 Ubuntu 22 默认使用 cgroup v2。

如何升级 Kubernetes 节点的 cgroup 版本?

需要在内核 5.4 及以上版本中配置,更新 GRUB 配置并重启系统。

如何查看 Kubernetes 节点上 Pod 的 cgroup 配置?

可以通过 DaemonSet 查看全部节点上 Pod 的 cgroup 配置。

启用 cgroup v2 需要注意什么?

需要确保内核版本在 5.4 及以上,并且 Containerd 和 Kubelet 的配置需设置为使用 cgroup v2。

➡️

继续阅读