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