- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有大约 10k 个视频流需要监控。将有一个小型集群(例如:5-10 个)的异构机器来监视这些流。由于没有足够的 CPU 来完成所有这些工作,我将不得不对流进行洗牌,一次监控其中的几个,然后切换到下一组。
现在,我的问题是..我想尽可能多地利用核心,这样我就可以使用发烧组,这样就可以更频繁地监控每个流。
流的分辨率不同,因此 CPU 使用率也不同。
nice -n 20
启动一个新进程,然后以某种方式检查它是否能够处理数据 (xx),如果可以,则将其重新调整为正常优先级,并且在下一个过程中尝试同样的事情......(xx:目前我不确定这是否可行..)您认为这些设计有什么缺陷吗?任何其他想法如何有效地做到这一点?
我的另一个问题是 linux 调度器..它能正确地分配进程吗?有 taskset
为进程设置 CPU 亲和性,手动控制分配是否有意义? (我认为是的)
此外,衡量进程 CPU 使用率的正确方法是什么?有 /proc/PID/stat
和 getrusage
,但它们都返回使用的 CPU 时间,但我需要一个百分比。 (注意:这个Q的优先级最低,如果没有回应我就去查看top
的来源)。我知道我可以使用 mpstat
监控内核。
最佳答案
也许我遗漏了什么,但为什么您需要将视频流分组到固定的集合中?
根据我对问题的理解,您基本上是对每个流进行采样并处理样本。如果我正在实现这样的事情,我会将所有流放在 a work queue 中, 最好支持 work stealing以尽量减少线程饥饿。
每个工作线程将从队列的头部获取一个流对象/描述符/URI/任何内容,对其进行采样和处理,然后将其移回队列的末尾。
CPU 利用率应该不是问题,除非由于实时限制,单个流不能总是使单个内核饱和。如果处理每个样本时的延迟不是问题,那么您有几个备选方案:
使用更多的处理线程,直到所有内核在所有情况下都得到充分利用。
使用单独的输入线程接收流 block 并传递那些 进行处理。这应该将网络延迟与实际流处理分离开来。
我不知道分布式系统(与单纯的 SMP 系统相对)的任何工作队列实现,但如果您找不到适合您需要的东西,构建您自己的一个应该相对容易...
关于linux - 利用多个进程使 CPU 饱和,以便进程仍然可以正常运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9500073/
每次我尝试构建(执行完整的 Clean,然后构建)时,我都会在 Eclipse 的问题部分下弹出此错误消息。项目本身旁边还显示一个错误。 我已经尝试了同一问题的其他解决方案中包含的所有内容: 删除项目
我收到以下错误(注意:我使用的是 Netbeans): java.sql.SQLException: No suitable driver found for jdbc:derby://localho
例如 //somewhere struct IFace; struct Base { Base(IFace* iface): f(iface) { //wi
我试图通过 stringstream 将 double 变成字符串,但它不起作用。 std::string MatlabPlotter::getTimeVector( unsigned int xve
我正在尝试使用 AudioKit 框架中的音序器播放音频文件。 AudioKit.output = sampler AudioKit.start() sampler.enableMID
昨天我问了一个关于插入 Heroku 的问题。它不工作,然后突然开始工作。我什么都没改变。现在在一个新的应用程序上,我遇到了完全相同的问题。我决定包含我的整个 Gemfile,希望我可以继续没有这种令
我知道,这个topic已经是discussed许多times,所以直截了当。 这是ItemsSource的TabControl: Tabs = new ObservableCollection {
我有一个更新对象的函数,问题是当我从更新表单字段返回到详细 View 时,它初始化旧对象而不是更新后的对象。 我想在 CarService 而不是 app.js 中填充汽车列表 这是我的汽车服务:
在 resolution comments错误报告 12266 (“套接字连接错误导致资源泄漏”),Robert Ehteshamzadeh 写道 TClientSocket is deprecate
我最初发布了一个问题 here 我发现 JTextField 仅在 JScrollPane 存在时才调整大小。换句话说,我可以根据需要最小化和最大化它,直到出现滚动条(因为文本太多,无法放入窗口)。之
我读过关于 postion:absolute 的问题并尝试了几乎所有可能的解决方案。包括相对定位 div,将它们包装在相对定位的父级中等等,但它没有帮助。 我正在绘制一个表格,然后我将 div 放入其
我在这里发起了一个话题document.getElementById not working但看起来即使提出的建议都是有效的,我仍然有问题。 我有几个复选框。当我在这里查看页面源代码时,有。 docu
我正在做一些阅读,试图更好地理解按位运算符,然后偶然发现了 a helpful old blog post from 2012 ,其中指出 - 在随机正整数 x 的奇数测试中 - 在作者的计算机上评估
我正在尝试在 Eclipse Neon 中使用 aspectj 创建一个示例 maven 项目。然而,方面并没有编织/工作(参见下面的输出)。我尝试寻找很多原因和解决方案,但没有一个有效(请参阅下面的
无论我如何配置我的 appsettings.json 和 appsettings.Development.json,除非我手动添加 ConfigureLogging,否则我无法在信息消息下方记录任何内
我正在尝试使用 JQuery .get() 方法和 JavaScript for 循环来处理来自外部文件的一些数据。我已经在 stackoverflow 上阅读了有关闭包和回调返回值的内容几个小时,但
我正在使用 PHP 5.6 并且要打印一些东西,我必须编辑 php.ini 并包含 php_printer.dll 文件。但是 PHP 5.6 没有.dll 文件。 我要解决的问题: 我想将凭证打印机
我目前正在调试一个包含内存泄漏的大(非常大!)C# 应用程序。它主要使用 Winforms 作为 GUI,尽管一些控件是在 WPF 中制作的,并由 ElementHost 托管。直到现在,我发现许多内
[已解决] 看来 PHP MYADMIN 变量成功了。我将 wait_timeout 设置为 30 ,并将 Lock_wait_timeout 设置为 50 花了将近 6 个小时才恢复稳定,包括几次重
我读过几个关于该主题的讨论,有人说 qmake < 3.0 不正确支持该指令。我刚刚为 g++-64 重新安装了 Qt 5.9.1,但问题仍然存在。此外,我尝试过各种 mkspecs/xxx/xxx.
我是一名优秀的程序员,十分优秀!