- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
目前我正在一台有 64 个内核的服务器上测试一个应用程序。此服务器安装了 virtualbox,最多可以使用 32 个内核但不能更多(此限制由 virtualbox 指定)。由于我正在使用 mininet 来测试我的应用程序,因此我需要 root 权限才能执行它。我在服务器上没有 root 权限,但在 VM 上没有。所以我的设置是:
主机有64核,安装了ubuntu
带有 ubuntu 的 virtualbox VM 有 1 - 32 个核心
我的应用程序在 16 台 mininet 主机上运行,每台主机都运行一个使用多播和单播相互通信的程序,但目前请求不多。启动后每个主机大约有 5 个请求。延迟3秒启动,避免启动瓶颈
我的应用程序使用多个线程,但主机上的每个应用程序实例都独立于其他应用程序实例
我的应用使用了python的APScheduler,完全是用python写的
我认为使用 32 个内核运行它是最好的。但是当我这样做时,一切都开始挂起。我在 APScheduler 中超时,系统负载非常高。
所以我尝试了 1 到 32 之间的每个核心数。以下是一些示例:
1个核心
4核
8 核
12 核
16 核
20个核心
23个核心
27 核
32 核
x 轴以半秒为单位,y 轴是 top -b -n 1 报告的 CPU 负载百分比。我用每个核心数运行应用程序大约 10 分钟。蓝线是我的应用程序的平均 CPU 负载。红线是我的应用程序,绿线是整个系统负载。
如您所见,负载降低到大约 16 个内核。当使用超过 16 个内核时,它会变得更慢,而从大约 23 个内核开始,它会变得非常慢。即使如此缓慢,甚至不再调用记录 CPU 负载的进程。这就是为什么最后一张图中的图表更短的原因......
有人知道可能是什么问题吗?这是 virtualbox 的已知错误吗?这是一个 mininet 问题吗?还是Linux问题?我怎么知道哪些部分导致了极端负载?
如果您需要更多信息,请发表评论,我会编辑问题。
guest 系统的负载从未超过 50%,所以我认为这不是问题所在。
VMWare 有可能更快吗?
编辑我查看了图表,发现描述我的应用程序平均 CPU 负载的蓝线(所有 mininet 主机上所有实例的平均值)在从 1 到 2 到 3 到 ... 16 个内核时甚至变得更高。但是从 1 核到 16 核,我的应用程序的 CPU 负载增加得非常非常慢。虽然这增加了整体系统负载下降(在我看来这是有道理的,因为 ubuntu 可以在不同的内核上执行其任务,只要没有共享资源,它就会更快)。
那么为什么均值在增加?为什么它从 16 核开始呈指数增长?
最佳答案
这是程序开始跨处理器插槽边界运行时的常见行为。通常,一旦您的应用程序开始在驻留在不同物理处理器上的内核上执行,您就会开始看到不可预测的时序行为。
假设您的 64 核机器有四个处理器插槽,每个插槽有 16 个内核,并且还假设您的调度程序是一个合理的调度程序,它试图将应用程序的线程分组在同一个插槽上,那么您的应用程序应该会看到良好的并行加速1 和 16 核,但一旦使用超过 16 核,它就会开始运行不佳,因为其中一些必须驻留在单独的插槽上。
对于常规机器和虚拟机都是如此,但是如果虚拟机的调度程序不知道这些套接字边界,则虚拟机可能会增加另一层不可预测性。
关于python - 从 16 个内核开始,向 virtualbox 添加更多内核会使应用程序变慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29543339/
我正在开发一个带选项卡栏的 ios 应用程序。我的栏上有超过 5 个按钮,所以在 iphone 上我有更多的按钮。现在,假设我有这个按钮:Button1 Button2 Button3 Button4
我有一个带有 UITabBarController 的应用,其中有超过五个选项卡。 当我按更多选项卡时,我会转到moreNavigationController,它是一个UINavigationCon
我有一个导航 Controller 。 NAVC->MORE... 按钮,然后在“更多”下有一些额外的 VC。 如果我转到“更多...”下的 VC,然后转到不在“更多...”上的 VC,那么当我返回到
因此,我想出了这种方案,用于在多个线程同时具有读写访问权限的二叉树中旋转时锁定节点,这涉及每次旋转锁定四个节点,这似乎是一个很多吗?我想到了一种比我想出的方法更聪明的方法来减少所需的锁定,但谷歌并没有
所以我已经尝试了所有方法,但我似乎仍然无法将下拉内容与 dropbtn 对齐。我只希望内容始终位于更多菜单下方。 HTML: `
我正在尝试使用 expect 来自动接受在 --more-- 中提示的 EULA。 #!/usr/bin/expect spawn "./greenplum-perfmon-web-4.1.2.0-b
他们如何在下面提供的网站上制作“告诉我更多”效果。我读过 read more/less effect in jQuery,但我发现该站点的有趣之处在于,除非单击该按钮,否则无法滚动页面。 Effect
现在,Kim Stebel helped me understanding如何使用存在类型键入变量,我需要知道如何在继承中使用它们: 以下代码无法编译: class PagingListModel(s
在我的Cygwin中不可用。另一方面,提供了“ less”命令。也许Cygwin的制造商认为“更多”只是多余的。 我对此很好奇。 最佳答案 安装util-linux软件包,您将获得“更多”的信息 ht
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我们使用 asp.net mvc、javascript 和 jQuery(托管在本地计算机上)创建了一个应用程序。基本设计是,当用户从一个页面导航到其他页面时,我们通过隐藏和显示 HTML 页面,将所
我想用 RMonad 做一些基本的事情。有没有办法使用“as monad”功能来 有一个身份 rmonad,可以应用 monad 转换器吗? 有诸如 StateT 变压器之类的常见东西吗? 向现有 m
我有一个 char*[] 数组。我需要能够为其分配字符串并再次删除它们,但我不知道: 如何检查一个元素中是否已经有一个字符串,这样我就不会覆盖它,如果它已经被占用,则继续处理下一个元素? 之后如何将其
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我有一个程序可以同时吐出标准错误和标准输出,我想在标准错误上少运行寻呼机,但忽略标准输出。我该怎么做? 更新: 就是这样......我不想丢失标准输出......只是让它远离寻呼机 program 2
基本上,当单击具有类 "dropdown" 的链接时,我无法获取“更多...”链接来对下一个跨度的高度进行动画处理。它根本就没有动画。仅当更改为 Less... 链接并且单击 Less... 链接以折
我正在使用 ExtJS,并认为它是一个了不起的框架。但是,它们没有内置的状态图,这使得依赖于状态的应用程序开发非常痛苦。 我最近发现了这个: https://github.com/jakesgordo
我一直在研究数据结构和算法,遗憾的是在C中。我已经单独实现了一个双向链表,它保存整数并且工作正常,但是当节点(或pub)让它正常工作时我遇到了很多麻烦在本例中)保存多个不同类型的值。我可以创建一个列表
编辑拼写错误 你好, 这可能是一个愚蠢的问题,但如果它能帮助我遵循最佳实践,我不在乎:P 假设我想在 System.Data 命名空间...以及 System.Data.SqlClient 命名空间中
使用 bootstrap 3 CSS、font awesome CSS 和最新的 jQuery JS 文件。 我正在使用 javascript 在单击按钮时在另一个内容 div 之上隐藏/显示一个内容
我是一名优秀的程序员,十分优秀!