【AICon】AI 基础设施、LLM运维、大模型训练与推理,一场会议,全方位涵盖! >>> 了解详情
写点什么

优化容器工作负载:Kubernetes 装箱的效益和挑战

作者 | Omer Hamerman

  • 2023-12-21
    北京
  • 本文字数:3768 字

    阅读完需:约 12 分钟

大小:1.81M时长:10:30
优化容器工作负载:Kubernetes装箱的效益和挑战

Kubernetes 已经成为容器编排事实上的标准,因此企业不断寻求优化其集群资源利用的方法。其中一种技术是装箱(bin packing):在集群中有效地分配资源,以最小化运行工作负载所需的节点数量。装箱使得企业能够通过减少支持应用程序所需的节点数量来降低成本。

 

在 Kubernetes 中,装箱的概念涉及在节点内部战略性地放置容器或“箱子(bin)”,以最大化资源利用率和减少资源浪费。如果实施得当,可以实现对硬件资源更有效的利用,并降低基础设施成本。在云环境中,这尤为重要,因为基础设施支出占据 IT 开支的相当大部分。

 

在本文中,我们将探讨在 Kubernetes 中进行装箱的复杂性,讨论与这种方法相关的挑战和权衡,并提供在企业中实现装箱的示例和最佳实践。

 

Kubernetes 装箱挑战

 

尽管 Kubernetes 中的装箱在资源利用和成本节约方面提供了显著的好处,但也带来了一些需要解决的问题。

 

密度与工作负载隔离和分发

 

实现装箱的一个主要问题是在最大化资源密度和保持工作负载隔离性之间找到平衡,同时要确保工作负载分布在系统和可用区(AZ)中,以御硬件故障。将容器高密度地打包到节点上可以提高资源利用率,但也可能增加对共享资源(如 CPU 和内存)争用的风险。

 

这可能导致性能下降,并可能影响整个集群的稳定性。此外,过度的装箱可能与分配的概念相矛盾,降低系统抵御硬件故障的能力。因此,我们有必要明智地并只在用例有意义的情况下应用装箱策略。

 

为了更深入地理解这种权衡的含义,有必要考虑密度的增加对集群容错性所造成的影响。当容器被高密度地打包到较少的节点上时,单个节点的故障可能对应用程序的整体健康和可用性产生更大的影响。这带来了一个问题:在节省成本的同时,如何确保你的工作负载对潜在故障的弹性?

 

在节点上过度集中应用程序的风险

 

在节点中过度装箱应用程序的风险与保持分布式部署的“最佳实践”是两个对立面。把所有的鸡蛋放在一个篮子里,这是典型的风险管理错误。这是一种操作风险,如果某些节点宕机,整个部署的更大部分也将随之离线。因此,一方面,出于弹性的考虑,你希望尽可能偏向分布式。另一方面,你希望控制成本,而装箱是一个很好地解决方案。在这种平衡中找到最佳的点才是关键。

 

当多个容器争用单个节点有限的资源(如内存或 CPU)时,这些问题变得更加明显,从而导致资源匮乏和应用程序性能下降。此外,以非逐渐方式或突发方式扩展系统还可能导致不必要的故障,进一步加剧这些挑战。为了应对这些不一致性,可以尝试设置策略限制,确保向应用程序提供可靠的资源。

 

在高密度装箱到节点时需要考虑的另一个问题是对维护和更新的潜在影响。随着在单个节点上运行更多的容器,对维护任务或软件更新的影响可能会被放大,导致更长时间的停机或降低应用程序性能。在进行装箱时,如何管理更新和维护而不对工作负载性能产生负面影响,是需要认真考虑的问题。

 

解决挑战的调度策略

 

Kubernetes 提供了几种调度策略来帮助解决与装箱相关的问题:

 

  • 资源请求和限制 允许你配置 Kubernetes 调度程序在进行调度决策时考虑每个节点上的可用资源,这使你能够将容器放置在具有适当资源量的节点上。

  • Pod亲和性和反亲和性规则 允许你根据其他 Pod 的存在来指定 Pod 应该或不应该放置在哪些节点上,这有助于确保工作负载在整个集群中均匀分布,或者根据特定要求在某些节点上进行分组。例如,处理基本客户数据的数据关键系统需要尽可能偏向分布式,以增强可靠性和性能。这种方法可以降低单点故障风险,带来更好的整体系统弹性。

  • Pod拓扑传播约束 使你能够考虑区域等因素,控制 Pod 在节点之间的分布方式。通过使用这些约束,你可以确保工作负载均匀分布,最大限度地减少单个节点过载的风险,并提高整体集群弹性。

 

通过仔细考虑和实施这些调度策略,你可以有效地解决在 Kubernetes 中进行装箱所面临的挑战,同时保持最佳的资源利用率和性能。

 

Kubernetes 装箱示例

 

关于在 Kubernetes 中如何有效地为不同类型的工作负载(从无状态的 Web 应用程序到数据库实例等)实施装箱,我们将在下面探讨其中一些示例。

 

无状态应用程序

 

Kubernetes 可以将多个无状态应用程序实例打包到单个节点中,同时确保每个实例都具有足够的资源。通过使用资源请求和限制,你可以引导 Kubernetes 调度程序为每个实例分配适当数量的 CPU 和内存。只要这些实例有足够的资源,它们就会启动并运行,并确保无状态应用程序(如 Web 应用程序或面向客户的应用程序)具有高可用性。

 

数据库实例

 

在处理数据库时,Kubernetes 可以有效地将不同有状态应用程序的单个实例打包到节点中,以最大化吞吐量和最小化延迟。通过利用 Pod 亲和性规则,你可以确保数据库实例放置在拥有必要的卷并与其他组件(如缓存服务器或应用程序服务器)接近的节点上。这有助于优化资源使用,同时保持数据库操作的高性能和低延迟。

 

批处理和机器学习工作负载

 

装箱也能给批处理和机器学习工作负载带来好处。Kubernetes 可以使用 Pod 拓扑传播约束确保这些工作负载均匀分布在节点上,防止资源争用,保持性能处于最佳状态。

 

大型多节点集群

 

如果需要将服务分布到大量节点(例如 2000 个节点)中,资源优化仍然是一个重要的考虑因素。虽然将这些服务分散开对于容错能力来说是必不可少的,但仍然需要考虑对剩余的服务进行装箱,以提高节点的利用率。

 

如果使用了特定的节点资源,Kubernetes 可以通过拓扑传播配置(例如PodTopologySpreadArgs)来管理它们。集群管理员和云供应商应该要确保节点得到相应的配置,以平衡分散的服务和装箱的服务。

 

通过理解和应用这些示例,你可以利用装箱来优化资源利用率,提高集群的整体效率。

 

Kubernetes 装箱的成本效益

 

通过在集群内有效地分配资源并最小化支持工作负载所需的节点数量,装箱有助于降低基础设施成本。这是通过将多个容器合并到较少的节点上实现的,减少了对额外硬件或云资源的需求。因此,企业可以在硬件、能源和维护方面节省开支。

 

在云环境中,基础设施成本占 IT 开支的很大一部分,因此通过装箱实现的成本节省可能非常显著。云提供商通常根据使用的节点数量和大小向客户收费,通过装箱优化资源利用率直接可以转化为减少云基础设施费用。

 

Kubernetes 装箱最佳实践

 

要充分利用 Kubernetes 装箱所带来的好处,需要遵循一些最佳实践,确保在防止出现性能问题的同时实现最佳资源利用。以下是三个重要的最佳实践。

 

谨慎的规划和测试

 

在 Kubernetes 环境中实施装箱之前,需要仔细规划和测试容器在节点中的放置。这可能涉及分析工作负载的资源需求,确定适当的密度水平,并在不同场景下测试集群的性能和稳定性。此外,设置内存的硬限制至关重要,因为内存是不可压缩的资源,应谨慎分配,以避免影响其他的应用程序。还要考虑潜在的内存泄漏问题,确保一个节点的内存泄漏不会在整个系统中造成混乱。

 

花一些时间进行规划和测试有助于避免与装箱相关的潜在问题,如资源争用和性能下降。

 

正确设置节点和容器大小

 

正确设置节点和容器大小是优化 Kubernetes 环境中资源利用的关键。为实现这一目标,首先需要评估应用程序的资源需求,如 CPU、内存和存储。这些信息有助于确定最适合的节点大小和容器资源限制,以最大限度地减少浪费和提高效率。为工作负载设置适当的节点和容器大小至关重要,因为如果你的容器太大并占用了节点相当比例的资源,那么你将无法将其他容器放置到节点上。例如,如果你运行一个非常大的容器,占用了每个节点 75%的资源,那么将导致 25%的浪费,无论你设置了多少装箱规则。在优化 Kubernetes 环境时,容器分配的资源和机器提供的资源是需要考虑的关键因素。

 

随时监控和调整

 

在 Kubernetes 集群中保持最佳资源利用需要进行持续的监控和调整。随着工作负载和需求的演变,可能需要重新评估装箱策略,以确保其有效性。

 

进行定期监控可以帮助你及早识别问题,如资源争用或未被充分利用的节点,让你能够在问题升级之前做出调整。

 

利用 Kubernetes 特性进行装箱

 

  • 资源配额 允许你限制命名空间可以消耗的资源量,确保不存在单个工作负载垄断集群的可用资源。

  • 资源请求和限制 可以让你引导 Kubernetes 调度程序将容器放置在具有适当资源量的节点上,这有助于确保工作负载被高效分配,并最小化资源争用。

 

另外需要考虑的一点是基础设施对环境的影响。通过装箱来优化资源利用,你可以潜在地减少企业的碳排放。运行较少的节点意味着消耗更少的能源并产生更少的热量,这有助于降低温室气体排放和降低对环境的影响。这带来了一个重要的问题:企业如何在追求成本效益和性能的同时,平衡其社会责任,以减少碳排放?

 

结论

 

在 Kubernetes 中进行装箱在优化资源利用和降低基础设施成本方面发挥着至关重要的作用,但同样重要的是如何在优化 Kubernetes 资源时正确找到效率和性能之间的平衡。

 

通过在集群中战略性地分配资源,企业可以将运行工作负载所需的节点数量降到最低,实现更低的支出和更高效的基础设施管理。

 

然而,正如讨论过的那样,企业需要面对与装箱相关的一些性能挑战和权衡以及在 Kubernetes 环境中有效使用装箱的最佳实践。通过理解和利用这些技术,企业可以最大限度地利用集群中的资源,节省基础设施成本,并提高总体效率。

 

原文链接

https://www.infoq.com/articles/kubernetes-bin-packing/


相关阅读:

50+ 顶级开源 Kubernetes 工具列表

Kubernetes 效应

你该如何为 Kubernetes 定制特性

用了就会更好吗?小心 Kubernetes 陷阱

2023-12-21 00:007302

评论

发布
暂无评论

掌握 CORS 跨域请求,读这一篇文章就够了

范家鹏

HTTP CORS 跨域 异步请求 跨域资源共享

前端面试指南之JS面试题总结

loveX001

JavaScript

基于阿里云IoT平台OTA进行APP确认升级的方案——业务架构类

阿里云AIoT

物联网 UED 数据格式

React Context源码是怎么实现的呢

flyzz177

React

Git实战(五)| 让工作更高效,搞定Git的分支管理

霍格沃兹测试开发学社

区块链“入局”证券市场,未来前景有多大?

旺链科技

区块链 产业区块链 证券行业 12 月 PK 榜

手把手教你构建数据安全体系,守住安全合规红线

王巍

数据安全

深入理解JS作用域链与执行上下文

loveX001

JavaScript

百度 Android 直播秒开体验优化

百度Geek说

android 百度app 12 月 PK 榜 直播优化

MYSQL-INNODB索引构成详解

京东科技开发者

MySQL innodb 索引 B+树 InnoDB存储引擎

面试官:MySQL 中 varchar(n) 中 n 最大取值为多少?

架构师之道

MySQL 编程 计算机

2小时开发《点球射门游戏》,动画演示思路(上),代码已开源

非喵鱼

Java 开源 游戏 12 月 PK 榜 世界杯足球游戏

软件测试 | 版本控制神器GitHub的基本使用与踩坑

测试人

GitHub 软件测试 自动化测试 测试开发

借用FinClip把小程序游戏运行到自有App中

Onegun

小游戏 小游戏开发 微信小游戏

前端工程师leetcode算法面试必备-二分搜索算法(上)

js2030code

JavaScript LeetCode

Git实战(四)| Git分支管理实操,搞定在线合并和本地合并

霍格沃兹测试开发学社

前端面试题(附答案)

loveX001

JavaScript

跨机房ES同步实战

京东科技开发者

迁移 迁移数据 异步多活 Elastic Search 数据库·

用javascript分类刷leetcode3.动态规划(图文视频讲解)

js2030code

JavaScript LeetCode

潦草手写体也能轻松识别,快速提取文字不用愁

HMS Core

HMS Core

IoT高级设备检索——设备管理运维类

阿里云AIoT

数据库 监控 物联网 传感器 Cloud Native

ZBC登录iZUMi Finance双挖池APY高达189%,极致通缩的典范

西柚子

做了一份前端面试复习计划,保熟~

loveX001

JavaScript

KAFKA EAGLE 监控MRS kafka之操作实践

华为云开发者联盟

开发 华为云 12 月 PK 榜

Idea居然还有比Navicat、Datagrid工具还好用、还快的插件,效率又可提升一倍了

非喵鱼

Java MySQL redis IDEA 12 月 PK 榜

ReactDOM.render在react源码中执行之后发生了什么?

flyzz177

React

前端刷完这12道滑动窗口,就可以出山面试了

js2030code

JavaScript LeetCode

算法 KECP 被顶会 EMNLP 收录,极少训练数据就能实现机器阅读理解

阿里云大数据AI技术

自然语言处理 机器学习 12 月 PK 榜 机器阅读

损失高达3亿美元|如何保护源代码安全?

SEAL安全

12 月 PK 榜 源代码安全 最小权限管理 零信任模型

极客时间运维进阶训练营第七周作业

9527

2 小时开发《点球射门游戏》,动画演示思路(下),代码已开源

非喵鱼

Java 开源 游戏 12 月 PK 榜 世界杯足球游戏

优化容器工作负载:Kubernetes装箱的效益和挑战_Serverless_InfoQ精选文章