基于 Pub/Sub 的同步 RRPC 调用实战

栏目: 后端 · 发布时间: 6年前

内容简介:MQTT协议是基于PUB/SUB的异步通信模式,无法实现服务端下发指令给设备端,同时需要设备端返回响应结果的场景。IoT物联网平台基于MQTT协议制定了一套请求和响应的同步机制,无需改动MQTT协议即可实现同步通信。应用服务器通过POP API发起RRPC调用,IoT设备端只需要在Timeout内,按照固定的格式回复Pub消息,服务端即可同步获取IoT设备端的响应结果。

1.同步调用场景

1.1 背景

MQTT协议是基于PUB/SUB的异步通信模式,无法实现服务端下发指令给设备端,同时需要设备端返回响应结果的场景。

IoT物联网平台基于MQTT协议制定了一套请求和响应的同步机制,无需改动MQTT协议即可实现同步通信。应用服务器通过POP API发起RRPC调用,IoT设备端只需要在Timeout内,按照固定的格式回复Pub消息,服务端即可同步获取IoT设备端的响应结果。

具体流程如下:

基于 Pub/Sub 的同步 RRPC 调用实战

1.2 Topic格式约定

基于 Pub/Sub 的同步 RRPC 调用实战

2.同步调用RRPC示例

2.1 设备端代码

基于 Pub/Sub 的同步 RRPC 调用实战

2.2 服务端POP调用Rrpc

基于 Pub/Sub 的同步 RRPC 调用实战

rrpc响应:

基于 Pub/Sub 的同步 RRPC 调用实战

3.物模型-服务同步调用

InvokeThingService示例

注意:物模型 服务调用 POP接口

是InvokeThingService,不是RRPC

基于 Pub/Sub 的同步 RRPC 调用实战

3.1 物模型- 同步服务定义

基于 Pub/Sub 的同步 RRPC 调用实战

3.2 设备端实现

基于 Pub/Sub 的同步 RRPC 调用实战

注意:设备端响应的payload要满足物模型定义的出参结构

3.3 物模型-服务调用

POP接口 InvokeThingService

基于 Pub/Sub 的同步 RRPC 调用实战

服务调用返回结果:

基于 Pub/Sub 的同步 RRPC 调用实战


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Pro Django

Pro Django

Marty Alchin / Apress / 2008-11-24 / USD 49.99

Django is the leading Python web application development framework. Learn how to leverage the Django web framework to its full potential in this advanced tutorial and reference. Endorsed by Django, Pr......一起来看看 《Pro Django》 这本书的介绍吧!

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

html转js在线工具
html转js在线工具

html转js在线工具