IPC消息队列溢出后果

Posted

技术标签:

【中文标题】IPC消息队列溢出后果【英文标题】:IPC message queue overflow consequences 【发布时间】:2020-07-01 05:34:01 【问题描述】:

我正在创建一个 C 应用程序,它将在 openwrt 路由器设备中执行。由于资源有限,我对消息队列有点害怕。如果从队列中获取消息的“读取器”应用程序崩溃并且“写入器”仍然发送消息怎么办?我应该担心设备的内存还是消息队列最终会自行清理?

编辑我意识到我对我的任务不够清楚。一个应用程序将发送消息,而另一个应用程序将读取和处理它们。

【问题讨论】:

什么类型的消息队列? 系统 V IPC。为此,我正在使用 库。 【参考方案1】:

见the documentation for msgsnd:

队列容量由消息队列的相关数据结构中的 msg_qbytes 字段控制。在队列创建期间,该字段被初始化为 MSGMNB 字节,但可以使用 msgctl(2) 修改此限制。

如果队列中的可用空间不足,则 msgsnd() 的默认行为是阻塞,直到空间可用。如果在 msgflg 中指定了 IPC_NOWAIT,则调用将失败并显示错误 EAGAIN。

所以发送者将等待接收者处理消息,除非你使用IPC_NOWAIT,在这种情况下它返回EAGAIN并且发送者可以检查这个错误代码。

默认的最大缓冲区大小在名为 MSGMNB 的常量中指定。您可以打印此值以查看它在您的系统上的内容。要更改队列的最大大小,可以使用函数msgctl

【讨论】:

以上是关于IPC消息队列溢出后果的主要内容,如果未能解决你的问题,请参考以下文章

IPC - 消息队列(Message Queue)- 使用

IPC - 消息队列(Message Queue)- 使用

IPC - 消息队列(Message Queue)- 使用

IPC之——消息队列

System V IPC 之消息队列

如何关闭/清除 IPC 消息队列?