Kubernetes: CPU Limits 是否能设置为 (200%)?

61次阅读
没有评论

问题描述

在使用 Kubernetes 时,遇到了一个关于 CPU Limits 设置的疑问。他在一个拥有 4 个 CPU 核心的集群节点上运行了两个 Pod。每个 Pod 的 CPU 资源请求设置为 500m,但是 CPU 资源限制设置为 4000m。通过运行 kubectl describe node <node> 命令,他发现 CPU 资源限制被显示为 8 (200%)。他理解这是因为有两个 Pod,每个 Pod 都将 CPU 限制设置为 4 个 CPU 核心。用户想知道这是语义问题还是潜在的问题。如果两个 Pod 都需要突发到 3 个 CPU 核心(低于各自的限制),是否可能会出现物理不可能的情况,而且它们只能降低使用资源。

解决方案

请注意以下操作可能存在版本差异,以及特定环境的配置需求。
根据回复中的信息,你的理解是正确的。Kubernetes 的 CPU 限制设置是按照百分比来表示的,这个百分比是相对于节点的物理 CPU 能力。如果你在同一个节点上运行的多个 Pod 的 CPU 限制总和超过了节点的物理 CPU 能力,Kubernetes 会使用时间片来分配可用资源,这是 CPU 方面没有太大问题的。

但是需要注意,内存方面可能会存在潜在的问题。如果你的 Pod 的资源限制总和达到了节点物理内存的 200%,并且这些限制总和超过了节点的物理内存能力,Kubernetes 的宿主主机内核会响应这种情况,可能会杀掉其中一个 Pod。如果你将资源请求设置得较低,可能会有更多的 Pod 被安排在同一节点上,但是将资源请求保持接近限制会增加 Pod 在节点上长期运行的机会。

关于你的具体问题,”是否存在所有 Pod 限制之和超过宿主节点 CPU 能力的潜在问题” 是一个值得考虑的问题。在实际运行中,Pod 之间并不会意识到它们位于同一节点上,因此在规划资源时要确保节点的物理 CPU 能力能够满足所有 Pod 的合理需求。在上述情况中,两个 Pod 的 CPU 限制之和确实达到了节点的物理 CPU 能力的 200%,如果这两个 Pod 同时需要突发到 3 个 CPU 核心,可能会超过节点的物理能力,导致它们只能在资源有限的情况下运行。因此,合理规划资源分配以及监控资源的使用是确保集群正常运行的关键。

在实际操作中,你可以根据自己的业务需求和资源情况来调整 Pod 的资源请求和限制,以保证整个集群的稳定性和性能。同时也可以考虑水平扩展集群,以适应更多的工作负载。

正文完