【发布时间】:2021-08-12 21:37:36
【问题描述】:
我们计划使用 MQTT 将消息从我们的服务器传送到安卓设备 我们决定使用开源服务器 mosquitto。
在大多数情况下,这就足够了。(发布/订阅) 但是我们有一种情况,客户端需要发送参数并从服务器获取响应。 我知道直接的方法是使用 Http(例如 Servlet)。 但是我们可以使用 MQTT 来实现这一点,因为这意味着用户的带宽消耗更低?
【问题讨论】:
我们计划使用 MQTT 将消息从我们的服务器传送到安卓设备 我们决定使用开源服务器 mosquitto。
在大多数情况下,这就足够了。(发布/订阅) 但是我们有一种情况,客户端需要发送参数并从服务器获取响应。 我知道直接的方法是使用 Http(例如 Servlet)。 但是我们可以使用 MQTT 来实现这一点,因为这意味着用户的带宽消耗更低?
【问题讨论】:
是的,它只需要仔细设计您的主题结构。举个非常简单的例子,你可以发布到control/<client id>/request,订阅control/<client id>/response
【讨论】:
从 MQTT 版本 5 开始,这是可能的。规范中指定了请求/响应模式。
【讨论】:
我建议你看看RabbitMQ handles RPC。虽然 AMQP 与 MQTT 不同,但仍有相当多的高级继承。
归结为您需要能够使用消息标头创建具有相关 ID 的临时“回复”队列。或者正如@ralight 所说,为每个客户打开两个队列。为每个客户端打开两个队列的问题当然是排序,因此您将不得不在内部使用关联 ID 和缓冲区和路由(如果您的应用是同步的,则删除直到找到关联 ID)。
【讨论】:
你也可以用 xargs 完成同样的事情。
下面是一个shell脚本示例:
mqtt_eg_link.sh
d=$(date +%Y-%m-%d)
mosquitto_pub -h <your host> -p 1880 -t status/ghost/log -m "$d >> eg listener running"
mosquitto_sub -h <your host> -p 1880 -t ghost | xargs -t -I {} cmd.exe /c eg.bat {}
【讨论】:
您应该使用等待/通知将发布/订阅转移到Dubbo框架DefaultFuture中使用的请求/响应,
【讨论】: