第 4-5 课:设备分组——功能设计

到目前为止, IotHub 一次只能对一个设备下发指令,假如业务系统需要对多台设备同时下发指令,应该怎么做呢?我们可以将设备进行分组,业务系统可以通过指定指令的设备组,来实现指令的批量下发。

设备分组

来看一下这个场景,业务系统要关闭二楼所有的 10 个传感器,在目前的 IotHub 功能设计下,业务系统需要调用 10 次下发指令接口,这显然是不合理的。 以 MQTT 的解决方案来说,这 10 个传感器都订阅一个 topic,比如: sensors/2ndfloor,只要往这个主题上发布一条消息就可以了,不需要每个设备都发布一次。

以上就是 IotHub 设备分组要实现的功能,业务系统可以通过 IotHub Server API 提供的接口,给设备设置一个或者多个标签,同时Server API提供接口,可以根据标签批量下发指令。 这样就实现了类似于设备分组的功能,拥有相同的标签的设备就相当于属于同一分组。

有两个问题是设备分组功能需要去解决的。

第一个是设备如何去订阅相应的标签的主题,到目前为止,IotHub 的设备端是通过 EMQ X 的服务器订阅功能完成订阅的,这设备分组的场景下,设备的标签是可以动态增加和删除的,所以无法使用 EMQ X 的服务器订阅功能。那么我们只能使用 MQTT 的 subscribe 和 unsubcribe 功能来完成标签的订阅。

第二个是设备如何知道自己应该订阅哪些标签的主题,在业务系统修改了设备的标签,IotHub 需要将设备的标签信息告知设备,这样设备才能去 subscribe 和 unsubscribe 相应的标签主题。IotHub 会同时使用 Push 和 Pull 模式来告知设备它

经验分享 程序员 微信小程序 职场和发展