MQTT协议接入

MQTT简介

MQTT(Message Queuing Telemetry Transport,消息队列遥测传输)协议是即时通信协议,是物联网的重要组成部分。

协议特点

MQTT协议是为大量计算能力有限,且工作在低带宽、不可靠的网络的远程传感器和控制设备通讯而设计的协议,它具有以下主要的几项特性:

1.使用发布/订阅消息模式,提供一对多的消息发布,解除应用程序耦合;

2.对负载内容屏蔽的消息传输;

3.使用 TCP/IP 提供网络连接;

4.小型传输,开销很小(固定长度的头部是 2 字节),协议交换最小化,以降低网络流量;

5.使用 Last Will 和 Testament 特性通知有关各方客户端异常中断的机制;

6.有三种消息发布服务质量:

    “至多一次”,消息至多发送一次。

    “至少一次”,确保消息到达,但消息重复可能会发生。

    “只有一次”,确保消息到达一次。

操作前提

1.已创建好产品和设备(产品管理、设备管理)
2.定义好产品模型(模型管理)

产品管理设备管理模型管理

获取连接认证参数

设备通过mqtt协议连接云服务,必须认证通过后才能成功建立连接。

【注意】直连设备(网关设备和普通设备)才允许连接

1)建立连接前先从平台获取认证需要的参数
参数 说明 获取路径
devId 设备ID 用户添加设备时输入的“设备ID”,在“设备管理”中可查看
pk 产品PK 平台“设备管理”,根据设备ID找到设备,点击列表右侧的“查看”,复制“设备信息”中的“产品PK”。
devSecret 设备秘钥 平台“设备管理”,根据设备ID找到设备,点击列表右侧的“查看”,复制“设备信息”中的“devSecret”。
2)构造MQTT连接的参数
参数 说明 构造方式
clientId 客户端ID dev:{pk}:{devId}
username 用户名 {hashMethod}:{random}
password 密码 hash(pk+devId+devSecret+random),加密密钥:devSecret。

【说明】

(1)参数间使用“:”隔开。
(2){hashMethod}支持:HmacMD5、HmacSHA1、HmacSHA256 和 HmacSHA512。
(3)password中加密使用的hashMethod、random需跟username中一致。

参数构造实例

Eg:pk=’pk123$’,devId=’1001$’,devSecret=’secret123$’,使用HashMD5方式进行加密,随机字符(random)为’20191108’。
clientId = dev:pk123$:1001$
username = HashMD5:20191108
password = c0608e3abe2f058df1d33020f963dbaf
password是通过HashMD5方法加密后得到。
要加密的字符串:pk123$1001$secret123$20191108,加密密钥:secret123$,加密后得到“c0608e3abe2f058df1d33020f963dbaf”。

在线工具

网关集群模式(IoT OS版本为1.4.18及以上支持)

网关 mqtt 连接共支持3种方式:

  • 单机模式
  • 广播模式
  • 集群模式

注意:仅支持 mqtt 方式连接的设备。

应用场景

构建高可用网关

单机模式

单机模式与普通设备连接无异,即 clientId 构造为:dev:{pk}:{devId},同一个设备作为不同客户端登录会不断顶替对方,造成重复登录。

发布 topic 为 up/dev/{pk}/{devId}

订阅 topic 为 down/dev/{pk}/{devId}

广播模式

clientId 构造为 dev:{pk}:{devId}:{random},比单机模式多了:{random},random 为随机字符串,建议6位长度左右的字母+数字作为随机值;同一个设备,如果 clientId 不一样,允许作为不同客户端同时登录 IoTOS 。

发布 topic 为 up/dev/{pk}/{devId}

订阅 topic 为 down/dev/{pk}/{devId},发给设备的每条消息,每个客户端都会收到相同的消息。

集群模式

订阅 topic 为 $share/gw/down/dev/{pk}/{devId}$share是固定写法,gw可以改为其他纯字母。发给设备的消息,会被随机分发给其中一个客户端,即使这条消息是被 A 客户端发送给 IoTOS 的,也可能是 A 收不到,而 B 客户端收到。

接入详情

使用MQTT.fx接入

使用SDK接入

results matching ""

    No results matching ""

    results matching ""

      No results matching ""