linux – POSIX消息队列 – mq_send线程唤醒命令

linux – POSIX消息队列 – mq_send线程唤醒命令,第1张

概述有人可以向我解释消息队列如何处理唤醒多个 线程在单个消息队列中被阻止? 我的情况是我有多个作者阻止完整的消息 队列,每个发布优先级等于线程的消息 优先.我想确保他们按优先顺序叫醒和发布, 但是我的应用程序表现得像是按FIFO顺序唤醒 (即他们阻止的顺序).每个阻塞线程都是 使用具有不同优先级的SCHED_FIFO策略进行调度 系统级范围. 我搜索了互联网的高低,以寻找描述如何的东西 这应该工作,我 有人可以向我解释消息队列如何处理唤醒多个
线程在单个消息队列中被阻止?

我的情况是我有多个作者阻止完整的消息
队列,每个发布优先级等于线程的消息
优先.我想确保他们按优先顺序叫醒和发布,
但是我的应用程序表现得像是按FIFO顺序唤醒
(即他们阻止的顺序).每个阻塞线程都是
使用具有不同优先级的SCHED_FIFO策略进行调度
系统级范围.

我搜索了互联网的高低,以寻找描述如何的东西
这应该工作,我所能找到的是描述它的POSIX手册页
如果优先级调度是多个阻塞,则按优先级顺序唤醒
支持的.由于内核调度程序是优先级调度程序
会认为线程会按优先级顺序唤醒并发布到
队列,但似乎并非如此.我敢肯定我
只是遗漏了一些微妙的细节,并希望专家在这里
这份清单可以帮助我了解我所看到的内容
这些线程准备好运行的内核级别.

我有一个小测试应用程序,如果有必要我可以在这里发布.它只是填充队列,然后有几个线程都尝试并写入它,所有线程优先级不同,并且发布的消息优先级等于线程优先级.然后我从队列中删除一条消息,并期望最高优先级的线程唤醒并发布其消息.但是,要等待的第一个线程首先发布其消息.

任何帮助或文档,任何人可以指出我,以便深入了解这个?

提前致谢!

解决方法 事实证明,如果队列已满,Linux内核会查看任务的优先级值,并以任务友好顺序将其添加到等待队列(这是非RT任务的优先级顺序).等待队列不符合我的应用程序使用的实时优先级.非RT优先级(漂亮的值)正在正确处理并以良好的顺序唤醒.

在将任务添加到内部内核等待队列时,我的问题的根本原因在于内核如何处理优先级.我向linux-kernel列表提交了一个补丁,该补丁已被接受,并将被用于未来的版本,这些版本在将任务添加到等待队列时更改了优先级检查 – 它现在既支持非RT优先级又支持RT优先级.它不处理截止日期计划任务的优先级.

总结

以上是内存溢出为你收集整理的linux – POSIX消息队列 – mq_send线程唤醒命令全部内容,希望文章能够帮你解决linux – POSIX消息队列 – mq_send线程唤醒命令所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/1017366.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-23
下一篇 2022-05-23

发表评论

登录后才能评论

评论列表(0条)

保存