博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
卸载(Offloading)vs. 加载(Onloading):谁是CPU利用率之王?
阅读量:6706 次
发布时间:2019-06-25

本文共 2089 字,大约阅读时间需要 6 分钟。

如今网络领域的主要争议话题之一是,是将网络功能加载到 CPU 上更合适,还是将这些功能卸载到互连硬件上更为理想。

Mellanox公司市场部副总裁Gilad Shainer

加载(Onloading)互连技术更易于实现,但问题在于对 CPU 利用率的影响由于CPU必须管理和执行网络操作,因此采用加载互连技术会降低其对应用程序的可用性——而这却是 CPU 的主要用途。

另一方面,卸载(Offloading)技术寻求克服 CPU 的性能瓶颈,主要方式是对在群集内移动的数据执行各种网络功能以及复杂的通信操作,如协同操作和数据聚集操作。当今数据分布范围广,在等待数据到达 CPU 处进行分析时就会产生性能瓶颈。相反,使用从 CPU 卸载这些功能的智能网络设备,就可在网络中的数据所在的位置进行操作。这一技术还有附加的优势:增加 CPU 对于计算功能的可用性,从而提升系统的整体效率。

CPU 利用率的问题是这两种技术选项之间的争论焦点。然而,计算 CPU 利用率的方式以及用于测试的基准会带来误导性很强的结果。

例如,常见错误是使用公共延迟测试或消息速率测试确定 CPU 利用率;然而,这些测试通常需要 CPU 频繁查找数据(即轮询内存中的数据),这就使得CPU看起来像是处于 100% 利用率,而实际上它完全没有工作。使用此类测试确定 CPU 利用率会产生虚假的结果。因为现实中,CPU 并不会频繁检查数据。

那么,测量 CPU 利用率的正确方式究竟是什么?在理想条件下,可使用数据带宽测试或不借助数据轮询的其他测试确定CPU利用率。或者,如果使用消息速率测试,则必须将此测试配置为避免陷入数据轮询循环,这样才能产生真实的结果。最终,最佳的选择是将实际执行的CPU指令数与测试持续期间可能已执行的 CPU 指令数进行比较。这样会得出准确的 CPU利用率百分比。

我们需要考虑的另一个重要因素是正在测量的开销类型。例如,如果测试设计为测量网络协议对 CPU利用率的影响,则应该仅测试在两台服务器之间传输的数据,而不包括额外的开销,如位于软件层中的MPI。如果目标是测量软件框架的开销,如MPI,则应使用MPI测试,但在此案例中,必须使用具备适当卸载功能的正确MPI(如果存在的话)。并不是所有的 MPI 都支持各种基于硬件的卸载,因此知晓测试的条件非常重要。

现在我们已了解如何精确地测量CPU利用率,那么剩下的问题就是:“哪种技术更为合适,卸载还是加载?”

我们在多台服务器之间进行了多次数据吞吐量测试,这些服务器分别通过EDR InfiniBand 和专有的Omni-Path 连接在一起。这些测试包括在测量 CPU 利用率时以每个互连支持的最大数据速率(大约 100 Gb/s)发送/接收传输的数据(参见表 1)。在数据速率为100 Gb/s的情况下,InfiniBand的 CPU 利用率仅为 0.8%,而为了执行相同的任务,Omni-Path的 CPU 利用率需要达到 59%。因此,在使用InfiniBand 时,CPU 对于应用程序的可用性是 99.2%;而在使用Omni-Path 时,仅有 40.4%的 CPU 周期可提供给应用程序。此外,我们在每种情况下都测量了 CPU 频率,因为 CPU 在不需要全速执行时会降低其频率以实现节能。在使用InfiniBand 时,CPU 频率能够降到其正常频率的 59%以实现节能。而在使用Omni-Path 时,CPU 全速执行,因此无法实现节能。

表 1 —— CPU 利用率比较:InfiniBand vs. Omni-Path

我们采用Intel 的Performance Counter Monitor 工具集检查 CPU 状态。该工具提供一组更丰富的测量方式来确定详细的系统状态。利用此工具,我们发现Omni-Path 的速度实际上未达到 100 Gb/s,而是稍低,为 95 Gb/s。AFREQ 状态报告在测试期间动态设置的 CPU 频率。我们还能够查看每个不同互连协议使用的迭代次数和活动周期数(参见表 2)。

表 2 —— Intel Performance Counter Monitor 工具统计数据对比

此外,在协同设计架构内的智能设备上部署InfiniBand 时,该产品还可通过卸载 MPI 操作来进一步减少 CPU 的开销。当然,为完成此次计算,测试必须确定在基准中包括软件层,这样才能获得准确的现实结果。我们计划未来进一步在不同的应用程序层面上执行多种测试,以证明InfiniBand的重大优势。

InfiniBand采用卸载技术,以降低 CPU 的负载,而最终的测试结果也正如我们所预料。如果其他测试结果与此处所示不同,则有必要调查测试环境,以更好地理解如何获得正确的结果。这些结果很有可能产生误导,无法准确反映现实的情况。(文/Mellanox公司市场部副总裁Gilad Shainer)

原文发布时间为:2016年7月5日

本文来自云栖社区合作伙伴至顶网,了解相关信息可以关注至顶网。

转载地址:http://jgblo.baihongyu.com/

你可能感兴趣的文章
linux shell 脚本之深入浅出的grep的用法
查看>>
Spring事务分类解释
查看>>
Qt 第二章 创建对话框--改变形状的对话框(一)
查看>>
Magent介绍
查看>>
让普通用户使用超级用户的权限
查看>>
Pandas+groupby用法讲解
查看>>
在libvirt 中体验容器
查看>>
字符串类的重量级实现——Rope的初步了解
查看>>
数据库镜像和日志传送配合完成高可用性以及灾难恢复
查看>>
突破单位wifi限制
查看>>
Windows Server 2016 + Exchange 2016 +Office365混合部署(四)
查看>>
windows server 2008下载及序列号
查看>>
Solaris 10源码安装编译出错的一种处理办法
查看>>
Cocos2d-x 2.x编程之CCNotificationCenter
查看>>
小计使用多线程和gevent来提高celery性能及稳定性
查看>>
ITIL好看不好吃?(五)
查看>>
【物联网智能网关-06】GPS定位+星图显示(WinForm库应用实例)
查看>>
Spark 的 Shell操作,核心概念,构建独立应用
查看>>
redis多实例重启脚本
查看>>
Lync 小技巧-16-查看Lync给谁打电话了
查看>>