天天看点

第 1-5 课:设备在线状态管理(一)

在本节中,我们将设计 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 的设备连接状态管理功能。

系统主题

EMQ X 使用许多系统主题发布 Broker 内部的状态和事件,你可以在这里看到系统主题的列表。

其中,订阅

$SYS/brokers/${node}/cl

继续阅读