gpt4 book ai didi

c++ - 一个 System v 消息队列用于多进程读/写的问题

转载 作者:行者123 更新时间:2023-11-30 19:29:05 24 4
gpt4 key购买 nike

我正在开发一个服务器程序,该程序通过多个子进程为多个客户端提供服务。我只使用一个 System V 消息队列在父进程和子进程之间进行通信。每个进程都会等待 mtype 等于进程 ID 的消息。每个子进程只与父进程通信。在父进程中,我使用标志 IPC_NOWAIT 调用 msgrcv 以防止被阻止处理其他内容。有2个子进程时,它可以按预期工作,但是当子进程数量增加时,会出现以下问题:

  • 如果我将 msgsnd 上的标志设置为 IPC_NOWAIT,则某些子进程无法向父进程发送消息,并出现错误 EAGAIN。如果我添加机制来重新发送带有此类错误的消息,它仍然会失败并且父进程不会收到消息。
  • 如果我从 IPC_NOWAIT 中取消设置 msgsnd 上的标志,则某些子进程将在对 msgsnd 函数的调用中被阻止。父进程没有收到任何消息。

所以:

  • 如何解决此问题?
  • 如果没有,您能为我推荐一位架构师来解决我的问题吗?

我的系统是Centos 7。消息大小为300字节。

最佳答案

未给出代码。最好是检查失败的返回值并引用联机帮助页。在 gdb 上,您可以单步执行到子进程无法发送消息的位置

关于c++ - 一个 System v 消息队列用于多进程读/写的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53280183/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com