哪个更适合本地IPC,POSIX消息队列(mqueues)或Unix域(local)sockets?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (3)
  • 关注 (0)
  • 查看 (55)

使用POSIX消息队列或Unix域socket进行本地IPC通信更好吗?

发送端的基本逻辑是:

connect to server
send request
note if the send worked or not
disconnect from server

一个服务器可以有数百个客户端。

我们正在运行Linux操作系统的SMP系统(4-8核)上执行。

提问于
用户回答回答于

与UNIX域数据报套接字相比,SysV消息队列具有我所知道的主要区别:

  • 你可以poll()套接字,但不能消息队列。
  • 消息队列是全局的,可能(而且通常需要)需要一些管理参与:清理旧的挂起的SysV资源是许多sysadmin日常例程之一。虽然UNIX域的语义要简单得多,而且应用程序通常可以在内部完全维护它,而不涉及sysadmin。
  • 消息队列是持久的,它可能会保留来自旧会话的消息。(无法准确地回忆起这一点,但IIRC不止一次发生在我身上)。
  • 看着man msgrcv我看不出套接字的类比MSG_PEEK很少需要,但有时会很方便。
  • 大多数情况下,用户更喜欢在配置符号名称中使用,而不是数字键id。缺少符号键,IMO是相当严重的监督部分SysV界面设计师。

与所有SysV资源一样,它们的管理是主要的PTAA。如果让系统决定消息队列ID,那么必须妥善地与其他应用程序共享它。(还必须以某种方式告诉管理员,最终必须删除ID)。如果允许配置消息队列的密钥,那么可能会遇到一些琐碎的问题,某些应用程序已经使用了id,或者是上一次运行的残余。(看到服务器重新启动只是因为它们耗尽了SysV资源,这是很常见的。)

总之,我尽量避免SysV资源:缺乏poll()在最常见的情况下,支持是一种破坏交易的手段。

然而,客户端并不等待“它已完成”的响应--尽管他们确实想知道他们的请求是否已经收到。

这是事务处理中常见的两难问题。一般的响应是(就像在RDBMS中一样),在通信中断(崩溃或其他什么)之后,应用程序必须检查自己是否已经处理了请求。

从这一点我可以看出,TCP可能是一个更好的选择。客户端发送请求,并且只有在从服务器获得积极响应时才声明它已完成。除非服务器能够向客户端发送响应,否则必须回滚事务。

热门问答

mqtt通信数据转发至另一Topic失败?

推荐已采纳

设置转发的这个产品的数据格式设置的是自定义,系统会认为所有数据都是二进制数据。如果需要使用json解析,需要设置产品数据格式是JSON。

腾讯云GPU服务器不能联外网吗?

小爱同学

腾讯云 · 技术支持 (已认证)

推荐
腾讯云GPU服务器可连外网,GPU 云服务器提供和标准CVM 云服务器一致的方便快捷的管理方式。 图片.png GPU云服务器作为CVM云服务器的一类特殊实例,购买、 操作、维护等方式与CVM云服务器一致 图片.png GPU 云服务器(GPU Cloud Computin...... 展开详请

win服务器怎么给文件夹配置755权限?

推荐
下面以腾讯云win服务器(Windows Server 2016 数据中心版 64位中文版)为文件夹配置755权限为例 1.右击【属性】 图片.png 2 .选择【安全】- 【编辑】 图片.png 3. 可对当前文件进行755权限配置 图片.png 要修改某个文件的权...... 展开详请

腾讯云sdk 兼容JDK6?

推荐

如果你说的是https://cloud.tencent.com/document/sdk/Java的话,jdk最低版本是1.7,不支持1.6

android 离线推送 为什么setOfflinePushListener不回调?

嗨喽你好摩羯座
推荐
您好,使用云通信 IM SDK 的通知栏提醒,建议参考:https://cloud.tencent.com/document/product/269/9234 中的描述来操作,通知栏提醒的内容由类 TIMOfflinePushNotification 来定义,可以通过这个类对外...... 展开详请

为什么cmq的topic配置订阅者为queue,向topic发送消息无法到达queue?

是的, 向topic发送消息应该会立即投递到订阅者。您可以检查您配置的队列名称是否正确且是真实存在的队列。如还不能解决您的问题,您可以点击控制台右上角的“工单”,进行问题进一步的排查,腾讯云会有专业的售后24小时为您服务。

所属标签

扫码关注云+社区