你真的了解 IoT 终端设备接入物联网平台的网络过程吗?

45f5f183a3fccbb70e18bbe63f2f44bd.png

如今,我们日常生活中每天都使用大量的物联网设备,比如智能门锁、地铁扫码闸机、早餐店收款播报音箱、汽车充电桩、上班刷脸打卡等,作为 IoT 物联网领域的开发者,你有想过背后完整的网络通信过程么?

借助全球开发者使用最广泛的开源抓包软件 Wireshark,抓取终端设备网卡通信包,一切就一目了然了。

6632c38473b62fcaded6d01449192be2.png

你会发现终端设备先做了DNS解析,再建立 MQTT 长连接通道,订阅业务主题,上报采集的数据,通过发送心跳包实现连接保活,业务处理完后主动断开长连接。

01

DNS 解析

DNS 服务是计算机域名系统 (Domain Name Service) 的缩写,它是由域名解析器和域名服务器组成的。域名服务器是指保存有该网络中所有主机的域名和对应IP地址,并具有将域名转换为IP地址功能的服务器。其中域名必须对应一个IP地址,而IP地址不一定有域名。

92978567207b76c81f9a6c95fc6116a2.png

观察DNS网络包,你会发现终端设备先去请求了 MQTT-Broker 服务器域名对应的 IP 地址。在 DNS 的 Answer 中终端设备获得了 addr 值,用于接下来的TCP/IP 网络连接。

02

TCP 三次握手

终端设备建立 MQTT 长连之前,需要先建立 TCP连接,即终端设备与MQTT-Broker 服务器的三次握手。

4aeb504f3802b1900de28e7ab9117052.png

03

MQTT 建立连接 CONNECT

MQTT(消息队列遥测传输) 是基于 TCP/IP 协议栈而构建的支持在各方之间异步通信的消息协议。MQTT 在空间和时间上将消息发送者与接收者分离,因此可以在不可靠的网络环境中进行扩展,使用了发布和订阅(Pub/Sub)的模型。

b77dff574ea8e977781c21c7007f01a4.png

在 TCP 连接基础上,终端设备主动发起 MQTT 的 CONNECT 指令,包含协议版本 v3.1.1,心跳时间 60s,连接标识 ClientId,用于认证的 Username 和 Password,如下图。

18dd25214aaf9dcee27b77e26f7e720b.png

MQTT-Broker 服务器收到终端设备建立连接请求,身份验证通过后,应答CONNACK报文,其中 ReturnCode 为0,如下图。

bd08089e490622364c2b0fbc6488d50d.png

19035b0a57e43a61d0e5317d6bd59516.png

04

MQTT 订阅主题 SUBSCRIBE

终端设备建立 MQTT 连接后,需主动订阅业务主题,用于接收云端下发的控制指令,如下图。

6a6cadf8344c11f4bcd8f84ca2326c82.png

MQTT-Broker 服务端成功建立订阅关系后,会给终端设备响应SUBACK,如下图。

d1312d69a1a318e8413fc02c12df4389.png

05

MQTT 上报数据 PUBLISH

终端设备采集到数据后,可以通过PUBLISH主动将数据发送到云端,同时设置消息主题Topic,数据报文Payload,以及QoS,如下图。

6bcdfd3344d4bb3d51bd929b367dcdbe.png

MQTT-Broker 服务端成功接收数据后,如果是QoS=1消息,会响应PUBACK,如下图。

3352f866cca7fbe02f3ac1685b39a6e5.png

06

MQTT 心跳 PINGREQ

当终端设备和 MQTT-Broker 服务器之间长时间没有业务包交互时,就需要通过心跳包 PINGREQ/PINGRESP 来实现网络长连接通道保活。

终端设备发送 PINGREQ 报文,如下图。

a9abd1d7329957afbf5c88d34c0d7075.png

MQTT-Broker 服务器响应PINGRESP报文,如下图。

2ff35e57ae508ec9efc8699d1fdd0cca.png

07

MQTT 心跳 DISCONNECT

当终端设备需要断开 MQTT 长连接时,可以MQTT-Broker 服务器主动发送DISCONNECT 报文,如下图。

bb4f83fdecb869f664626a907b72d404.png

08

TCP 连接断开

当终端设备的 MQTT 长连接断开后,TCP 也会随之销毁,如下图。

9b1532ef92ed50d7bceb2a9ba583c38d.png

以上就是通过 Wireshark 网络抓包工具,从终端设备视角抓包分析 IoT 物联网设备完整网络通信过程,希望对你有所帮助!

往期推荐

☞ 十年回望,中国物联网平台消亡史

☞ IDC中国 IoT物联网平台评估报告

☞ IoT物联网平台趋势: 私有化

☞ 5个值得分享的物联网创业失败教训

☞ 国内 4 大 IoT物联网平台选型对比

☞ 云厂商的「IoT物联网平台不香了吗?

6c2862d6db9bdcd41bc7ef2c924406e5.png

83f2bc7cbc5e7b81b1fabf1a5eeaea86.gif

31c7bd2a8d73ea0d40da80eda8656057.gif

e89fff7ca7753eba96a1708cadb254ee.gif

60c503736d9e84d374d8b6eccfd1b293.gif

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值