您当前的位置:首页 > 电脑百科 > 程序开发 > 容器

Kubernetes:裸机vs虚拟机性能对比

时间:2023-11-27 15:05:23  来源:微信公众号  作者:云云众生s

本文对Kube.NETes集群在虚拟机和裸机上在CPU、内存、存储和网络性能方面的表现进行了详细的比较和分析。

译自Does Kubernetes Really Perform Better on Bare Metal vs. VMs?,作者 Oleg Zinovyev 是 Gcore 的技术内容编辑,Gcore 是一家全球云边缘提供商。他在与云原生技术(包括 Kubernetes)相关的各种公司有超过 5 年的撰稿经验。在转向写作之前,Oleg 曾担任过......

许多人认为部署在物理机上的 Kubernetes 集群性能比部署在虚拟机上的要好,但直到现在还没有任何证据支撑这一假设。在 Gcore,我们只向客户提供有充分证据支撑的信息,所以我们决定自己测试一下 K8S 部署在物理机和虚拟机上的性能是否真的有差异,如果有的话差异有多大。我将分享我们内部测试的结果。

我有意不讨论物理机节点与虚拟节点的其他方面的竞争,比如成本效益或基础设施控制水平。这已经超出了本文的范围,本文仅专注于性能比较。

当您在虚拟机上部署 Kubernetes 集群时,与物理机相比,您会得到额外的基础架构层——一个虚拟机管理程序(hypervisor)和一个虚拟机操作系统。

 

Kubernetes:裸机vs虚拟机性能对比图 1:物理机和虚拟机架构的区别。

这些层会消耗物理 CPU 和 RAM 来运行,从而占用了一些计算能力。虚拟化也会影响网络和存储性能:虚拟网络和存储比物理网络和存储慢。

相比之下,当您在物理服务器上部署 Kubernetes 集群时,您不会有任何额外的基础架构层和虚拟化。服务器的物理资源完全专用于您的工作负载,并且容器化应用程序直接访问这些资源。

我们如何比较虚拟机和物理机 Kubernetes 性能

为了全面了解虚拟机和物理机集群性能的比较,我们测量了以下指标:

  • CPU: 速度和利用率
  • RAM: 延迟
  • 存储: 每秒事务数(TPS)和延迟
  • 网络: 带宽和延迟

为了实验的纯净性,所有测试应用程序都是容器化的,并部署在正在比较的工作节点上。

我们的测试条件

为了测试,我们使用了在 Gcore 托管 Kuberneteshttps://gcore.com/cloud/managed-kubernetes 上运行的 K8s 集群。但是,结果也适用于原生 Kubernetes,因为托管 Kubernetes 不会增加工作节点性能的额外开销。

为了使工作负载保持相同的条件,我们选择了类似配置的虚拟机和物理机工作节点。以下是这样的对比配置的一个示例:

  • 物理机工作节点: 1x Intel Xeon E-2388 8C/16T 3.2 GHz / 64 GB / Ubuntu 22.04
  • 虚拟机工作节点: 16 vCPU / 64 GiB 内存 / Ubuntu 22.04

测试结果摘要

在测试中,我们比较了两个 Kubernetes 集群,一个部署在虚拟机(VM)上,另一个部署在物理机上。它们的配置相似。作为测试工作负载,我们运行了:

  • CPU基准测试用于 CPU 测试
  • Sysbench 用于 RAM 测试
  • Pgbench 用于存储测试
  • Netperf 用于网络测试

下表总结了最重要的测试结果:

Kubernetes:裸机vs虚拟机性能对比图 2:测试结果摘要。

显然,在所有情况下,物理机集群的效率都更高。

我们将在本文后面详细检查结果,并确定更好的物理机性能对您的工作负载意味着什么。但是首先,让我们简单回顾一下在虚拟机上部署的 Kubernetes 集群与物理机上的基本区别。

详细的测试结果

现在让我们详细看一下物理机和虚拟机集群在每个评估标准方面的性能。

CPU 速度和利用率

对于 CPU 速度比较,我们使用了 Alex Dedyura 的CPU 基准测试。这是一个计算 π 到 10,000 位小数的脚本。计算时间以秒为单位,在 10 次测试中取平均值,作为测试结果。计算 π 是一个 CPU 密集型任务,因此基准测试可以清楚地表明所测试 CPU 的性能。

以下是 CPU 速度比较结果:

Kubernetes:裸机vs虚拟机性能对比图 3:物理机集群的 CPU 速度比虚拟机集群的 CPU 快两倍多。

虚拟机集群的 10 次重试平均时间为 47.07 秒;对于物理机集群,它是 21.46 秒。因此,物理机集群速度快了两倍多。

以下是虚拟机集群的 CPU 利用率测试结果:

Kubernetes:裸机vs虚拟机性能对比图片

图 4:虚拟机集群的 CPU 平均利用率为 86.81%。

Kubernetes:裸机vs虚拟机性能对比图 5:虚拟机集群 CPU 每个核心的利用率信息。

在上面的图 4 中,红点是最大 CPU 核心负载,绿色代表所有核心的总 CPU 负载。在执行脚本期间,核心大部分时间以 100% 的利用率运行;平均值为 86.81%。在 15:16 左右还有一个小的抢占时间峰值,这是当一个虚拟机由于等待物理 CPU 共享其计算资源而不执行的常见情况。

*最大 CPU 核心负载: 此指标通常指在 VM 内或跨 VM 主机上观察到的单个 CPU 内核的最高利用率百分比。它指示某个特定 CPU 内核被利用的程度。**所有内核的总 CPU 负载:此指标表示主机上所有可用 CPU 内核的总体 CPU 利用率。它考虑到所有 CPU 内核的组合使用情况,并提供有关主机上运行的所有 VM 使用的 CPU 容量的整体视图。

以下是物理机集群的 CPU 利用率测试结果:

Kubernetes:裸机vs虚拟机性能对比图 6:物理机集群的 CPU 平均利用率为 43.75%。

平均 CPU 负载约为 43.75%,最大值为 62.57%,没有抢占时间。因此,就 CPU 性能而言,测试表明物理机集群的效率约为虚拟机集群的两倍。

RAM 延迟

对于 RAM 测试,我们使用了 sysbench并通过 RAM 传输了 6400 GB 的数据。以下是执行的写操作和读操作的关键结果:

Kubernetes:裸机vs虚拟机性能对比图片

 7:物理机集群的 RAM 速度比虚拟机集群快约三倍。

虚拟机集群的写入平均时间为 174.53 毫秒,而物理机集群进行相同操作的时间为 62.02 毫秒。读操作分别在 173.75 和 47.33 毫秒内完成。

这意味着物理机集群的 RAM 速度比虚拟机集群的 RAM 快约三倍。

存储 TPS 和延迟

为了测试存储性能,我们运行了一个 PostgreSQL 集群,并使用pgbench 基准测试。我们测量了 TPS(每秒事务数)和延迟。我们还改变了工作负载,在相同的集群配置上测试了 8GB 和 75GB 数据库。

以下是实例的配置:

Kubernetes:裸机vs虚拟机性能对比图 8:存储测试的物理机和虚拟机集群配置。

存储 TPS 结果

以下是 TPS 比较的平均结果:

 

Kubernetes:裸机vs虚拟机性能对比图片

图 9:物理机集群的存储 TPS 值约为虚拟机集群的两倍。

运行 8GB 数据库时,虚拟机集群显示 7,359 TPS,而物理机集群为 14,087 TPS。75GB 数据库的性能结果分别为 4,636 和 12,029 TPS。

存储延迟结果

以下是延迟测试的平均结果:

Kubernetes:裸机vs虚拟机性能对比图 10:物理机在存储延迟方面优于虚拟机。

运行 8GB 数据库时,虚拟机集群的延迟为 34.78 毫秒,而物理机集群的延迟为 18.17 毫秒。对于 75GB 数据库,延迟分别为 55.21 毫秒和 21.28 毫秒。

运行8GB数据库时,物理机集群的存储性能约为虚拟机集群的两倍。对于75GB数据库,物理机集群相对于虚拟机集群的优势更加明显。

网络带宽和延迟

为了测试网络性能,我们使用了netperf基准测试,最大报文段大小(MSS)范围从1到65,536。MSS中的“段”元素是通过网络传输的一种IP数据包束。因此,MSS越大,传输的流量就越大。

我们在两个物理节点上部署了三个工作节点:Worker 1和Worker 2位于第一个节点上,Worker 3位于第二个节点上。然后我们测试了所有三个工作节点之间的网络性能。结果趋势在所有情况下都是相似的——物理机优于虚拟机。

最有趣的测试是工作节点之间物理距离最大的测试,即当流量在第一个和第二个物理节点之间流动时,Worker 1/Worker 2(在第一个节点上)和Worker 3(在第二个节点上)之间的距离。我们可以认为这是所有测试中最具挑战性的条件。图10和图11显示了此测试的结果。图10显示了MSS值为1、2、4和8时的网络带宽比较:

Kubernetes:裸机vs虚拟机性能对比图11:物理机集群的网络带宽是虚拟机集群的5倍。

虚拟机集群的带宽范围从 MSS=1 时的 862KB/sec 到 MSS=8 时的 6.52MB/sec,而物理机集群的带宽范围从 MSS 值为 4.17MB/sec 到 31MB/sec。平均而言,物理机集群的带宽是虚拟机集群的 5 倍。

图 12 显示了使用相同 MSS 值的网络延迟比较:

Kubernetes:裸机vs虚拟机性能对比图 12:物理机集群的网络延迟最高可降低虚拟机集群的 6 倍。

正如我们所见,在 MSS=8 时测量,虚拟机集群的延迟约为 145 微秒,而物理机的延迟为 24.5 微秒,高出约 6 倍。此外,对于物理机集群,随着 MSS 的增加,延迟的增长速度更慢。

对于所有测试,请注意,我们报告的是集群网络内部的网络性能比较。我们测量了一个网络内部节点之间的带宽和延迟,位于一个位置。如果我们使用不同位置的节点,这将增加互联网延迟,而互联网延迟是不稳定的,并且可能因提供商而异。我们在合成条件下保持纯净;它们可能无法在实际环境中复制。但是,可以预期普遍趋势得以重现。

物理机性能优势的意义

与虚拟机相比,更好的物理机性能提供了两个简单但关键的优势:

  • 部署在物理机工作节点上的应用程序运行和响应速度比部署在虚拟机上的快。
  • 因此,当您选择物理机时,客户使用您的产品体验会更好。

我们的测试结果证明了一个常识,即对需要高性能和低延迟的计算密集型工作负载(例如数据库、AI/ML 模型和其他类型的实时应用程序)来说,物理机确实更好。虚拟机适合对计算和延迟不敏感的工作负载,例如 Web 服务器、网站和开发环境。如果高性能和低延迟对您的用户至关重要,并直接影响您的业务,您应该考虑在 Kubernetes 集群中使用物理机。

结论

我们的测试证实了物理机工作节点优于虚拟机工作节点的假设。我们还产生了关于物理机工作节点确实优于多少的具体数据,即:

  • CPU 速度和利用率提高两倍
  • RAM 延迟降低三倍
  • 存储性能提高两倍以上
  • 网络延迟降低五倍以上

如果您想在物理机工作节点上试用 Kubernetes,请查看Gcore 的托管 Kubernetes。我们提供了几种类型的工作节点配置,包括用于加速 AI/ML 工作负载的 NVIDIA GPU。

我要感谢我在 Gcore 的同事进行测试并帮助撰写本文: Sergey Kalinin、Sergey Mikhalev 和 Andrei Novoselov。



Tags:Kubernetes   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
Kubernetes 究竟有没有 LTS?
从一个有趣的问题引出很多人都在关注的 Kubernetes LTS 的问题。有趣的问题2019 年,一个名为 apiserver LoopbackClient Server cert expired after 1 year[1] 的 issue 中提...【详细内容】
2024-03-15  Search: Kubernetes  点击:(5)  评论:(0)  加入收藏
Kubernetes 集群 CPU 使用率只有 13% :这下大家该知道如何省钱了
作者 | THE STACK译者 | 刘雅梦策划 | Tina根据 CAST AI 对 4000 个 Kubernetes 集群的分析,Kubernetes 集群通常只使用 13% 的 CPU 和平均 20% 的内存,这表明存在严重的过度...【详细内容】
2024-03-08  Search: Kubernetes  点击:(12)  评论:(0)  加入收藏
聊聊 Kubernetes 网络模型综合指南
这篇详细的博文探讨了 Kubernetes 网络的复杂性,提供了关于如何在容器化环境中确保高效和安全通信的见解。译自Navigating the Network: A Comprehensive Guide to Kubernete...【详细内容】
2024-02-19  Search: Kubernetes  点击:(37)  评论:(0)  加入收藏
Kubernetes是什么?主要特点是什么?
Kubernetes是什么?Kubernetes,也称为K8s,是一个开源的容器编排系统,由Google首次开发和维护。它允许容器化的应用程序在集群中自动部署、扩展和管理。Kubernetes提供了一种容器...【详细内容】
2024-02-01  Search: Kubernetes  点击:(153)  评论:(0)  加入收藏
开发者的Kubernetes懒人指南
你可以将本文作为开发者快速了解 Kubernetes 的指南。从基础知识到更高级的主题,如 Helm Chart,以及所有这些如何影响你作为开发者。译自Kubernetes for Lazy Developers。作...【详细内容】
2024-02-01  Search: Kubernetes  点击:(50)  评论:(0)  加入收藏
Kubernetes Informer基本原理,你明白了吗?
本文分析 k8s controller 中 informer 启动的基本流程不论是 k8s 自身组件,还是自己编写 controller,都需要通过 apiserver 监听 etcd 事件来完成自己的控制循环逻辑。如何高...【详细内容】
2024-01-30  Search: Kubernetes  点击:(37)  评论:(0)  加入收藏
Kubernetes 100个常用命令!
这篇文章是关于使用 Kubectl 进行 Kubernetes 诊断的指南。列出了 100 个 Kubectl 命令,这些命令对于诊断 Kubernetes 集群中的问题非常有用。这些问题包括但不限于:• 集...【详细内容】
2024-01-03  Search: Kubernetes  点击:(76)  评论:(0)  加入收藏
一文读懂Kubernetes部署策略
在这篇文章中,我们将深入研究 Kubernetes 部署概念和一些常见策略,了解每种策略的优缺点。合适的部署策略使我们能够在发布应用程序时最大限度地减少停机时间、增强客户体验并...【详细内容】
2024-01-03  Search: Kubernetes  点击:(58)  评论:(0)  加入收藏
从Kubernetes的探针到DevOps
今天在群里又看有人问如何设置 Kubernetes 的探针,感觉要补充的话太多了,结合我们在一些 DevOps 项目中痛苦的体验,今天一劳永逸的全部说完,此外,也为大家展现一下为什么 DevOps...【详细内容】
2023-12-27  Search: Kubernetes  点击:(113)  评论:(0)  加入收藏
如何基于Kubernetes运行Nacos高可用集群
Nacos(Namings and Configuration Management)是阿里巴巴开源的一个易于构建云原生应用的动态服务发现、配置管理和服务管理平台。以下是Nacos的一些主要功能和特点: 服务发现...【详细内容】
2023-12-18  Search: Kubernetes  点击:(68)  评论:(0)  加入收藏
▌简易百科推荐
Docker 和传统虚拟机有什么区别?
我有一个程序员朋友,他每年情人节都要送女朋友一台服务器。他说:“谁不想在过节当天收到一台 4核8g 的服务器呢?”“万一对方不要,我还能留着自己用。” 给他一次过节的机会,他能...【详细内容】
2024-03-26  小白debug  微信公众号  Tags:Docker   点击:(11)  评论:(0)  加入收藏
掌握Docker网络驱动程序:优化容器通信
Docker为在容器内包装、交付和运行应用程序提供了一个强大的平台,从而彻底改变了容器化。网络是容器化的重要组成部分,Docker提供了各种网络驱动程序来支持容器之间的通信以...【详细内容】
2024-03-22    51CTO  Tags:Docker   点击:(10)  评论:(0)  加入收藏
Containerd容器管理
Nginx 指定容器名称 使用 ctr container create 命令创建容器后,容器并没有处于运行状态,其只是一个静态的容器。容器基本操作容器基本操作主要是 ctr image 命令,查看命令帮...【详细内容】
2024-03-20  云原生运维圈  微信公众号  Tags:容器   点击:(13)  评论:(0)  加入收藏
如何基于Docker镜像逆向生成Dockerfile
引言你是否曾经遇到过一个想要使用的 Docker 镜像,但却无法修改以适应你的特定需求?或者你可能发现了一个喜欢的 Docker 镜像,但想要了解它是如何构建的?在这两种情况下,将 Docke...【详细内容】
2024-03-07  云原生运维圈  微信公众号  Tags:Docker   点击:(22)  评论:(0)  加入收藏
Kubernetes是什么?主要特点是什么?
Kubernetes是什么?Kubernetes,也称为K8s,是一个开源的容器编排系统,由Google首次开发和维护。它允许容器化的应用程序在集群中自动部署、扩展和管理。Kubernetes提供了一种容器...【详细内容】
2024-02-01    简易百科  Tags:Kubernetes   点击:(153)  评论:(0)  加入收藏
我们一起聊聊容器资源自愈
在企业实际在使用容器这类资源的时候,除了技术本身,要考虑的其他问题也会很多。企业管理的容器有千千万万,出于效率考虑,对于有特殊需求的容器如何进行批量创建和管理呢,这就需要...【详细内容】
2024-01-30  匠心独运维妙维效  微信公众号  Tags:容器   点击:(47)  评论:(0)  加入收藏
Docker与Docker Compose入门:释放你应用部署的威力
今天给大家介绍一项强大而有趣的技能,那就是使用 Docker 和 Docker Compose 来释放你的应用部署的威力!无论你是一名开发人员还是系统管理员,掌握这个技能都将为你的工作带来巨...【详细内容】
2024-01-17  waynblog  微信公众号  Tags:Docker   点击:(65)  评论:(0)  加入收藏
Docker镜像与容器的交互及在容器内部执行代码的原理与实践
Docker作为一种流行的容器技术,已经成为现代应用程序开发和部署的重要工具。在Docker中,镜像是构建和运行容器的基础,而容器则是基于镜像创建的可执行实例。Docker镜像与容器的...【详细内容】
2024-01-10  编程技术汇  今日头条  Tags:Docker   点击:(75)  评论:(0)  加入收藏
如何在 Ubuntu 上安装 Docker
使用 Docker 意味着开启一个新的计算领域,但如果你刚刚开始使用 Docker,安装可能看起来是一项艰巨的任务。在 Ubuntu 上安装 Docker 有两种推荐的方法: 从 Ubuntu 的仓库安装 D...【详细内容】
2024-01-04    Linux中国  Tags:Docker   点击:(124)  评论:(0)  加入收藏
从Kubernetes的探针到DevOps
今天在群里又看有人问如何设置 Kubernetes 的探针,感觉要补充的话太多了,结合我们在一些 DevOps 项目中痛苦的体验,今天一劳永逸的全部说完,此外,也为大家展现一下为什么 DevOps...【详细内容】
2023-12-27  云云众生s  微信公众号  Tags:Kubernetes   点击:(113)  评论:(0)  加入收藏
站内最新
站内热门
站内头条