在本节中,我们将设计 IotHub 的设备在线状态管理功能。
如何得知一个设备是在线或离线,是大家经常问到的问题,也是在实际生产中非常必要的一个功能。
Poor man's Solution
MQTT 协议并没有在协议级别约定如何对 Client 的在线状态进行管理,在《MQTT 协议快速入门》里我介绍过一个解决思路:
- Client 在连接成功时向 TopicA 发送一个消息,指明 Client 已经上线;
- Client 在连接时指定 LWT,Client 在离线时向 TopicA 发送一个 Retained 消息,表示已经离线;
- 只要订阅 TopicA 就可以获取 Client 上线和离线的状态了。
这个解决方案在实际上是可行的,但是有一个问题就是,你始终需要保持一个接入 Broker 的 Client 来订阅 TopicA,如果说设备的数量往十万甚至几十万上去了,这个订阅 TopicA 的 Client 就很容易成为单点故障点,所以说这种解决方案的可扩展性比较差。
使用 EMQ X 的解决方案
EMQ X 提供了丰富的管理功能和接口,所以我们会使用 EMQ X 提供的功能来实现 IotHub