当前位置:  开发笔记 > 运维 > 正文

单个docker容器在cpu性能方面稍微优于其主机:为什么?

如何解决《单个docker容器在cpu性能方面稍微优于其主机:为什么?》经验,为你挑选了0个好方法。

我运行了一个实验,将docker容器的CPU性能与运行它的主机的CPU性能进行比较.

案例

:在主机上运行的基准程序(Intel i5,2.6 GHz,2个处理器,2个内核)
B:在同一台主机上运行的Docker容器上运行基准程序.(对于B中的容器没有资源限制.即容器本身拥有所有1024个cpu共享.没有其他容器正在运行)

基准计划:数值整合

数值积分:是大规模并行程序的标准示例.使用OpenMP lib以C++编写的标准数字集成示例程序(已经过测试,以确保其正确性).程序从1-11开始,通过程序中不同数量的可用线程运行11次.对于每个案例A和B,完成了这11次运行.因此,对于主机和11对于容器,总共执行22次运行.

X轴:程序中可用的线程数

Y轴:表示与时间相反的性能(通过将运行程序的时间倒数乘以常数计算得出).

结果 在此输入图像描述

意见

在主机上运行的docker容器略微优于主机.该实验在2个不同的宿主上重复4-5次,每次容器性能曲线略高于宿主性能曲线.

当docker容器在主机上运行时,容器性能如何高于主机?

可能的原因:docker cgroup进程的优先级较高?

我假设容器的cgroup中的进程可能获得更高的进程优先级,从而导致程序在容器内运行的性能更高,而程序直接在主机上运行时.这听起来像是一个可能的解释吗?

推荐阅读
360691894_8a5c48
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有