首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >MQTT 协议快速体验

MQTT 协议快速体验

原创
作者头像
EMQ映云科技
修改于 2022-10-09 04:20:08
修改于 2022-10-09 04:20:08
1.6K0
举报
文章被收录于专栏:EMQ 物联网EMQ 物联网

全球物联网正在高速发展,专门针对低带宽和不稳定网络环境的物联网应用设计的 MQTT 协议也因此得到广泛应用。

MQTT 是一种基于发布/订阅模式轻量级消息传输协议,具有简单易实现、支持 QoS、报文小等特点,非常适用于工业互联网、车联网、智能硬件、电力能源等领域。

本文将通过讲解与演示向读者展示 MQTT 协议的入门使用流程,物联网及 MQTT 初学者可以通过本文以更简单的方式理解 MQTT 相关概念,快速开始 MQTT 服务及应用的开发。

MQTT 连接

在使用 MQTT 协议进行通信之前,需要先建立一个 MQTT 连接,连接由客户端向服务器端发起。

MQTT 客户端

任何运行了 MQTT 客户端库的程序或设备都是一个 MQTT 客户端,例如:使用了 MQTT 的即时通讯 APP 是一个客户端,使用 MQTT 上报数据的各种传感器设备是一个客户端,以及各种 MQTT 测试工具也是一个客户端。

目前,基本所有的编程语言都有成熟的开源 MQTT 客户端库,读者可参考 EMQ 整理的 MQTT 客户端库大全选择一个合适的客户端库来构建满足自身业务需求的 MQTT 客户端。也可直接访问 EMQ 提供的 MQTT 客户端编程系列博客,学习如何在 Java、Python、PHP、Node.js 等编程语言中使用 MQTT。

本次演示我们将使用由 MQTT X 提供的支持浏览器访问的在线 MQTT 客户端:http://www.emqx.io/online-mqtt-client。MQTT X 是目前开源客户端中 GitHub Star 数最多的,它同时也提供了桌面客户端(https://mqttx.app/zh)与命令行客户端(https://mqttx.app/zh/cli),感兴趣的读者可自行下载使用。

MQTT 服务器

MQTT 服务器负责接收客户端发起的连接,并将客户端发送的消息转发到另外一些符合条件的客户端。一个成熟的 MQTT 服务器可支持海量的客户端连接及百万级的消息吞吐,帮助物联网业务提供商专注于业务功能并快速创建一个可靠的 MQTT 应用。

MQTT 服务器一般有私有部署、全托管云服务、公共在线三种形式。

  • 私有部署需要自行搭建与维护服务器,适合接入量较大、且有技术团队支持的公司。

读者若是希望搭建私有 MQTT 服务器进行测试,可运行如下 Docker 命令直接安装 EMQX 开源版。

代码语言:text
复制

docker run -d --name emqx -p 1883:1883 -p 8083:8083 -p 8084:8084 -p 8883:8883 -p 18083:18083 emqx/emqx

代码语言:txt
复制

也可参考博客如何在 Ubuntu 上安装 EMQX MQTT 服务器进行安装。

  • 全托管云服务免除了企业维护基础设施的负担,简单几步就能轻松开启 MQTT 服务。如下图,EMQX Cloud 支持按连接创建 MQTT 服务,且可选择部署在多个云平台。
MQTT Cloud
MQTT Cloud
  • 公共的在线服务器一般由各个 MQTT 服务器的所属商业公司所提供,主要用来做 MQTT 流程测试。

本次演示我们将使用由 EMQ 提供的公共 MQTT 服务器,该服务器基于全托管的 MQTT 云服务 - EMQX Cloud 创建,服务器信息如下:

  • Broker: broker.emqx.io
  • TCP Port: 1883
  • Websocket Port: 8083

创建连接

接下来我们开始正式创建一个 MQTT 连接,使用浏览器访问 http://www.emqx.io/online-mqtt-client,然后点击页面中间的 New Connection 按钮,将会看到如下页面。

创建 MQTT 连接
创建 MQTT 连接

各个连接的参数的意义如下:

  • Name:为该在线客户端特有,只是一个区分不同连接的名称,与连接的建立无关系。使用代码连接时没有该参数。
  • Client ID:服务端使用 Client ID 识别客户端,连接服务端的每个客户端都必须要有唯一的 Client ID。
  • Host:为连接的服务器地址及协议,协议一般有 4 种:基于普通 TCP 的 MQTT、基于 SSL/TLS 的 MQTT、基于 WebSocket 的 MQTT,基于加密 WebSocket 的 MQTT。本文使用的在线工具基于浏览器运行,所以只能选择 ws 或 wss 协议。
  • Port:连接的服务器端口。
  • Path:选 ws 或 wss 协议时需要填写,EMQX 服务器默认为 /mqtt
  • Username,Password:MQTT 可以通过发送用户名和密码来进行相关的认证和授权,但是,如果此信息未加密,则用户名和密码是以明文的方式发送的。
  • Connect Timeout:连接超时时间,连接在多少秒内未成功则不再继续连接。
  • Keep Alive:保活周期,是一个以秒为单位的时间间隔。客户端在无报文发送时,将按 Keep Alive 设定的值定时向服务端发送心跳报文,确保连接不被服务端断开。更多细节可查看博客:MQTT 协议中的 Keep Alive 机制
  • Clean Session:清除会话,为 false 时表示创建一个持久会话,在客户端断开连接时,会话仍然保持并保存离线消息,直到会话超时注销。否则表示创建一个新的临时会话,在客户端断开时,会话自动销毁。
  • Auto Reconnect:自动重连,几乎所有客户端库都实现了自动重连。如果设置了自动重连,当网络不佳连接被断开后,客户端将自动重新发起连接。
  • MQTT Version:MQTT 版本,建议使用 5.0。MQTT 5.0 是为适应迅速增长的设备数量与企业需求而全面更新的一个版本,其在 3.1.1 版本基础上增加了会话/消息延时、原因码、主题别名、用户属性、共享订阅等更加符合现代物联网应用需求的特性。更多 MQTT 5.0 详细信息可查看 EMQ 提供的 MQTT 5.0 专题系列文章。

我们在 Name 里输入 Simple Demo,并点击右上角的 Connect 按钮即可创建一个 MQTT 连接,如下表示连接建立成功。

MQTT 连接成功
MQTT 连接成功

发布与订阅

连接成功后,客户端就能进行消息的收发,在消息收发前我们需要先理解发布/订阅模式。

发布/订阅模式

发布订阅模式区别于传统的客户端-服务器模式,它使发送消息的客户端(发布者)与接收消息的客户端(订阅者)分离,发布者与订阅者不需要建立直接联系。我们既可以让多个发布者向一个订阅者发布消息,也可以让多个订阅者同时接收一个发布者的消息,它的精髓在于由一个被称为代理(MQTT 服务器)的中间角色负责所有消息路由和分发的工作。

下图为 MQTT 的发布/订阅流程:温度传感器作为一个客户端连接至 MQTT 服务器后,即可向某个主题(比如 Temperature)发布温度消息,服务器收到该消息后会将消息转发至订阅了 Temperature 主题的客户端(比如下图的手机、浏览器等应用)。

发布订阅模式
发布订阅模式

主题(Topic)

MQTT 协议基于主题进行消息路由,主题类似 URL 路径,例如:

代码语言:shell
AI代码解释
复制
chat/room/1

sensor/10/temperature

sensor/+/temperature

主题通过 / 分割层级,支持 +# 通配符:

  • +:表示通配一个层级,例如 a/+ 匹配 a/xa/y
  • #:表示通配多个层级,例如 a/# 匹配 a/xa/b/c/d

更多关于 MQTT 主题的介绍可查看博客:MQTT 主题的高级特性

消息服务质量(QoS)

MQTT 协议提供了 3 种消息服务质量等级(Quality of Service),它保证了在不同的网络环境下消息传递的可靠性。

  • QoS 0:消息最多传递一次。

如果当时客户端不可用,则会丢失该消息。发布者发送一条消息之后,就不再关心它有没有发送到对方,也不设置任何重发机制。

  • QoS 1:消息传递至少 1 次。

包含了简单的重发机制,发布者发送消息之后等待接收者的 ACK,如果没收到 ACK 则重新发送消息。这种模式能保证消息至少能到达一次,但无法保证消息重复。

  • QoS 2:消息仅传送一次。

设计了重发和重复消息发现机制,保证消息到达对方并且严格只到达一次。

更多关于 MQTT QoS 的介绍可查看博客:MQTT QoS 服务质量介绍

订阅主题

接下来我们模拟温度传感器场景,在之前创建的 Simple Demo 连接里订阅所有的温度传感器上报的温度数据,即订阅通配符主题 sensor/+/temperature

如下图,点击按钮 New Subscription,在弹出框的 Topic 下面输入主题 sensor/+/temperature,QoS 保持默认 0 不变。

Color 字段可修改订阅标签的颜色,Alias 字段可修改订阅主题的显示名称。这两个字段为该在线客户端特有,使用代码连接时无此参数。

订阅 MQTT 主题
订阅 MQTT 主题

订阅成功后即可看到中间的订阅列表里多了一条记录。

主题订阅成功
主题订阅成功

发布消息

接下来我们点击最左侧的 + 按钮分别创建 Sensor 1Sensor 2 两个连接,模拟两个温度传感器。

创建 MQTT 连接
创建 MQTT 连接

连接创建好后如下图所示,将会看到 3 个连接,并且连接左侧的在线状态圆点都为绿色(绿色说明连接成功)。

连接创建成功
连接创建成功

选中 Sensor 1 连接,在页面右下部分输入发布主题 sensor/1/temperature,消息框内输入如下 JSON 格式消息,并点击右侧最底部的发布按钮发送消息。

代码语言:json
AI代码解释
复制
{
  "msg": "17.2"
}
发布 MQTT 消息
发布 MQTT 消息

如下表示消息发送成功。

消息发布成功
消息发布成功

使用同样的步骤,在 Sensor 2 连接里向 sensor/2/temperature 主题发布如下 JSON 消息。

代码语言:json
AI代码解释
复制
{
  "msg": "18.2"
}

将会看到 Simple Demo 连接收到 2 条新消息。

消息通知
消息通知

点击 Simple Demo 连接,将会看到两个传感器发送的两条消息。

收到两条 MQTT 消息
收到两条 MQTT 消息

MQTT 重要特性演示

保留消息(Retained Message)

MQTT 客户端向服务器发布消息时,可以设置保留消息标志。一个主题下最新一条保留消息会驻留在消息服务器,后来的订阅者订阅主题时仍可以接收该消息。

如下图,我们在 Sensor 1 连接里向 retained_message 主题发送两条不一样的消息,且发送消息时勾选 Retain 选项。

MQTT 保留消息
MQTT 保留消息

然后,我们再在 Simple Demo 连接里订阅 retained_message 主题,订阅成功后将会收到 Sensor 1 发送的第二条保留消息,由此可见服务器只会保存一个主题下最后一条保留消息。

MQTT 保留消息
MQTT 保留消息

清除会话(Clean Session)

一般情况下 MQTT 客户端仅能接收到在线时其他客户端发布的消息,如果客户端离线再上线后将收不到离线期间的消息。但是当客户端使用固定的 Client ID,且连接参数 Clean Session 为 false 时,客户端离线后消息服务器可以为客户端保持一定量的离线消息,并在客户端再次上线后发送给客户端(且为客户端恢复下线前的订阅信息)。

本次演示使用的公共 MQTT 服务器设置的离线消息保存时间为 5 分钟,最大消息数为 1000 条,且不保存 QoS 0 消息。接下来我们创建一个 MQTT 3.1.1 版本的连接,并验证 QoS 1 情况下的离线会话。

MQTT 5 中使用 Clean Start 与 Session Expiry Interval 改进了 Clean Session,详情可查看博客:Clean Start 与 Session Expiry Interval

如下图,创建一个名为 MQTT V3 的连接,Clean Session 设置为 false,MQTT 版本选择 3.1.1。

MQTT 清除会话
MQTT 清除会话

连接成功后订阅 clean_session_false 主题,且 QoS 设置为 1。

订阅 MQTT 主题
订阅 MQTT 主题

订阅成功后,点击右上角的断开连接按钮。

断开 MQTT 连接
断开 MQTT 连接

接下来创建一个名为 MQTT_V3_Publish 的连接,MQTT 版本同样设置为 3.1.1,连接成功后向 clean_session_false 主题发布三条消息。

发布 MQTT 消息
发布 MQTT 消息

然后选中 MQTT_V3 连接,点击连接按钮连接至服务器,将会成功接收到 3 条离线期间的消息。

MQTT 离线消息
MQTT 离线消息

遗嘱消息(Last Will)

MQTT 客户端向服务器发起连接请求时,可以设置是否发送遗嘱消息(Will Message)标志,和遗嘱消息主题(Topic)与内容(Payload)。设置了遗嘱消息消息的 MQTT 客户端异常下线时(客户端断开前未向服务器发送 DISCONNECT 消息),MQTT 消息服务器会发布该客户端设置的遗嘱消息。

更多关于遗嘱消息的介绍可查看博客:MQTT 遗嘱消息(Will Message)的使用

如下图,我们创建一个名为 Last Will 的连接。

  • 为了能快速看到效果,我们设置 Keep Alive 为 5 秒
  • Last-Will Topic 设置为 last_will
  • Last-Will QoS 设置为 1
  • Last-Will Retain 设置为 true
  • Last-Will Payload 设置为 offline
MQTT 遗嘱消息
MQTT 遗嘱消息

连接成功后,我们断开电脑网络 5 秒钟以上(模拟客户端异常下线),再打开网络。然后启动 Simple Demo 连接,并订阅 last_will 主题,将会收到 Last Will 连接设置的遗嘱消息。

MQTT 遗嘱消息
MQTT 遗嘱消息

至此,我们完成了对 MQTT 相关基础概念及其使用流程的讲解与演示,读者可以根据本文所学尝试上手使用 MQTT 协议。接下来读者可访问 EMQ 提供的 MQTT 客户端编程系列博客,学习如何在 Java、Python、PHP、Node.js 等编程语言中使用 MQTT,开始 MQTT 应用及服务开发,探索 MQTT 的更多高级应用。

版权声明: 本文为 EMQ 原创,转载请注明出处。

原文链接:https://www.emqx.com/zh/blog/the-easiest-guide-to-getting-started-with-mqtt

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
​MQTT 持久会话与 Clean Session 详解
不稳定的网络及有限的硬件资源是物联网应用需要面对的两大难题,MQTT 客户端与服务器的连接可能随时会因为网络波动及资源限制而异常断开。为了解决网络连接断开对通信造成的影响,MQTT 协议提供了持久会话功能。
EMQ映云科技
2022/11/07
1.6K0
MQTT 协议入门:基础知识和快速教程
本文是 MQTT 协议的入门指南,提供了实用的代码示例。物联网和 MQTT 的初学者可以通过本文掌握 MQTT 的基本概念,快速开启 MQTT 服务和应用的开发。
EMQ映云科技
2023/06/27
1.7K0
MQTT 协议入门:基础知识和快速教程
EMQX从搭建到作用于MQTT
​ 1. 协议与实现:MQTT 是一种协议,定义了消息发布、订阅、分发的标准;而 EMQX 是基于此协议实现的消息代理服务。EMQX 支持 MQTT 3.1、3.1.1 和 5.0 版本的协议。
一只牛博
2025/05/31
3290
EMQX从搭建到作用于MQTT
Java物联网开发(一) —— MQTT协议
官方文档传送门 mqtt官网 mqtt中文网 mqtt 3.1.1 英文文档 mqtt 5.0 英文文档 b站mqtt教程
时间静止不是简史
2021/08/12
11.3K0
Java物联网开发(一)  —— MQTT协议
mqtt服务器搭建(ubuntu)
MQTT(Message Queuing Telemetry Transport,消息队列遥测传输协议),是一种基于发布/订阅(publish/subscribe)模式的”轻量级”通讯协议,该协议构建于TCP/IP协议上,由IBM在1999年发布。MQTT最大优点在于,可以以极少的代码和有限的带宽,为连接远程设备提供实时可靠的消息服务。作为一种低开销、低带宽占用的即时通讯协议,使其在物联网、小型设备、移动应用等方面有较广泛的应用。
全栈程序员站长
2022/09/06
8.1K0
mqtt服务器搭建(ubuntu)
MQTT 协议基本介绍
MQTT 全称为 Message Queuing Telemetry Transport(消息队列遥测传输)是一种基于发布/订阅范式的“轻量级”消息协议,由 IBM 发布。
sunsky
2021/06/09
3.9K0
MQTT 协议基本介绍
一文搞懂MQTT,如何在SpringBoot中使用MQTT实现消息的订阅和发布
之前介绍了RabbitMQ以及如何在SpringBoot项目中整合使用RabbitMQ,看过的朋友都说写的比较详细,希望再总结一下目前比较流行的MQTT。所以接下来,就来介绍什么MQTT?它在IoT中有着怎样的作用?如何在项目中使用MQTT?
章为忠学架构
2023/10/06
22.4K2
一文搞懂MQTT,如何在SpringBoot中使用MQTT实现消息的订阅和发布
MQTT协议学习总结
海量的设备接入和设备管理对网络带宽、通信协议以及平台服务架构都带来了很大挑战。对于物联网协议来
叫我阿杰好了
2022/11/07
4K0
MQTT协议学习总结
车联网移动场景 MQTT 通信优化实践
随着智能化浪潮席卷全球,如今的车辆早已不再是单纯的交通工具,而是一个具备自主推理能力、能和云端交互进行车路协同的移动智能节点。
EMQ映云科技
2022/10/24
9660
为什么最近每份 Android 简历都说 “熟悉 MQTT 协议”?
MQTT 是一种基于发布 - 订阅模型的消息传递协议,在物联网和移动应用有较广泛的应用。如果你的目标是冲击中高级工程师岗位,MQTT 或许是一个不错的亮点。最近,我还发现很多候选人会在简历中写自己 “熟悉 MQTT 协议”,但多数人只是停留在了解或用过的程度。
用户9995743
2022/12/22
4.6K0
为什么最近每份 Android 简历都说 “熟悉 MQTT 协议”?
MQTT over QUIC:下一代物联网标准协议为消息传输场景注入新动力
本文将通过对 MQTT over QUIC 的详细解析,为大家展现这一领先技术实现对于物联网场景的优势与价值,帮助大家更有效地借助 EMQX 5.0 对 QUIC 的支持能力,在各类 MQTT 应用场景中进行更加高效、低成本的物联网数据传输。
EMQ映云科技
2022/07/29
7770
基于 RocksDB 实现高可靠、低时延的 MQTT 数据持久化
MQTT 协议标准中规定 Broker 必须存储离线客户端的消息。在之前的版本中,EMQX 开源版采用了基于内存的会话存储,企业版则在此基础上进一步提供了外部数据库存储方案,借此实现数据持久化。
EMQ映云科技
2022/08/08
1.1K0
Java物联网开发(二) —— 开源百万级分布式 MQTT 消息服务器EMQX
Mnesia 数据库是 Erlang 内置的一个分布式 DBMS,可以直接存储 Erlang 的各种数据结构 EMQ X 使用 Mnesia 数据库存储自身运行数据,例如告警记录、规则引擎已创建的资源和规则、Dashbaord用户信息等数据,这些数据都将被存储在 mnesia 目录下,因此一旦删除该目录,将导致 EMQ X 丢失所有业务数据。可以通过 emqx_ctl mnesia 命令查询 EMQ X 中 Mnesia 数据库的系统信息。
时间静止不是简史
2021/08/12
8.1K0
Java物联网开发(二) —— 开源百万级分布式 MQTT 消息服务器EMQX
MQTT 发布/订阅模式介绍
发布订阅模式(Publish-Subscribe Pattern)是一种消息传递模式,它将发送消息的客户端(发布者)与接收消息的客户端(订阅者)解耦,使得两者不需要建立直接的联系也不需要知道对方的存在。
EMQ映云科技
2023/01/12
2.6K0
原 荐 EMQ百万级MQTT消息服务(小技巧)
附上: 喵了个咪的博客:w-blog.cn EMQ官方地址:http://emqtt.com/ EMQ中文文档:http://emqtt.com/docs/v2/guide.html 1.ACL鉴权规
喵了个咪233
2018/04/16
1.5K0
原  荐   EMQ百万级MQTT消息服务(小技巧)
为什么智能硬件首选MQTT
前面讲了Android如何通过串口通信操作硬件,但实际业务场景大多是既可以屏幕操控硬件也可以远程下发操控,这时就需要MQTT协议来完成这一工作。本文将介绍MQTT协议及其在物联网设备通信中的应用。
Coder昊白
2023/11/22
8970
为什么智能硬件首选MQTT
MQTT协议通俗讲解
基本概念 Basic Conception Session 会话 定义 定义:某个客户端(由ClientID作为标识)和某个服务器之间的逻辑层面的通信 生命周期(存在时间):会话 >= 网络连接 ClientID 客户端唯一标识,服务端用于关联一个Session 只能包含这些 大写字母,小写字母 和 数字(0-9a-zA-Z),23个字符以内 如果 ClientID 在多次 TCP连接中保持一致,客户端和服务器端会保留会话信息(Session) 同一时间内 Server 和同一个 ClientID 只能保持一个 TCP 连接,再次连接会踢掉前一个 CleanSession 标记 在Connect时,由客户端设置 0 —— 开启会话重用机制。网络断开重连后,恢复之前的Session信息。需要客户端和服务器有相关Session持久化机制。 1 —— 关闭会话重用机制。每次Connect都是一个新Session,会话仅持续和网络连接同样长的时间。 客户端 Session 已经发送给服务端,但是还没有完成确认的 QoS 1 和 QoS 2 级别的消息 已从服务端接收,但是还没有完成确认的 QoS 2 级别的消息 服务器端 Session 会话是否存在,即使会话状态的其它部分都是空 (SessionFlag) 客户端的订阅信息 (ClientSubcription) 已经发送给客户端,但是还没有完成确认的 QoS 1 和 QoS 2 级别的消息 即将传输给客户端的 QoS 1 和 QoS 2 级别的消息 已从客户端接收,但是还没有完成确认的 QoS 2 级别的消息 (可选)准备发送给客户端的 QoS 0 级别的消息 长连接维护与管理 Keep Alive 心跳 目的是保持长连接的可靠性,以及双方对彼此是否在线的确认。 客户端在Connect的时候设置 Keep Alive 时长。如果服务端在 1.5 * KeepAlive 时间内没有收到客户端的报文,它必须断开客户端的网络连接 Keep Alive 的值由具体应用指定,一般是几分钟。允许的最大值是 18 小时 12 分 15 秒 Will 遗嘱 遗嘱消息(Will Message)存储在服务端,当网络连接关闭时,服务端必须发布这个遗嘱消息,所以被形象地称之为遗嘱,可用于通知异常断线。 客户端发送 DISCONNECT 关闭链接,遗嘱失效并删除 遗嘱消息发布的条件,包括: 服务端检测到了一个 I/O 错误或者网络故障 客户端在保持连接(Keep Alive)的时间内未能通讯 客户端没有先发送 DISCONNECT 报文直接关闭了网络连接 由于协议错误服务端关闭了网络连接 相关设置项,需要在Connect时,由客户端指定 Will Flag —— 遗嘱的总开关 0 -- 关闭遗嘱功能,Will QoS 和 Will Retain 必须为 0 1 -- 开启遗嘱功能,需要设置 Will Retain 和 Will QoS Will QoS —— 遗嘱消息 QoS 可取值 0、1、2,含义与消息QoS相同 Will Retain —— 遗嘱是否保留 0 -- 遗嘱消息不保留,后面再订阅不会收到消息 1 -- 遗嘱消息保留,持久存储 Will Topic —— 遗嘱话题 Will Payload —— 遗嘱消息内容 消息基本概念 报文标识 Packet Identifier 存在报文的可变报头部分,非零两个字节整数 (0-65535] 一个流程中重复:这些报文包含 PacketID,而且在一次通信流程内保持一致: PUBLISH(QoS>0 时),PUBACK,PUBREC,PUBREL,PUBCOMP SUBSCRIBE, SUBACK UNSUBSCIBE,UNSUBACK 新的不重复:客户端每次发送一个新的这些类型的报文时都必须分配一个当前 未使用的PacketID 当客户端处理完这个报文对应的确认后,这个报文标识符就释放可重用。 独立维护:客户端和服务端彼此独立地分配报文标识符。因此,客户端服务端组合使用相同的报文标识符可以实
PM吃瓜
2019/08/20
2.6K0
用了那么久MQTT,这些知识点你了解吗
哈喽,小伙伴们,今天来聊一聊什么是MQTT协议,以及常用的几个术语是什么意思,有图有真相哦,欢迎阅读
用户8913398
2021/08/16
5.2K0
用了那么久MQTT,这些知识点你了解吗
什么是MQTT Last Will and Testament (LWT)遗嘱和遗言?
我们这期就针对LWT详细介绍和说明,大家看完有任何建议和指导留言区留言讨论哈!!!
Hello工控
2025/05/19
2070
什么是MQTT Last Will and Testament (LWT)遗嘱和遗言?
MQTT Keep Alive 参数有什么用途?
在物联网网络中,有些设备的数量少,3台到5台,也可能很庞大,成千上万台。例如,传感器,包括磁性接触传感器、功率计、椅子占用传感器等。无论客户端的数量是多少,很可能并不是所有的设备都会持续传输数据。比如,如果冰箱内的温度发生变化,冰箱的传感器会发送一条关于这个变化的消息。在其他时间,这个客户端保持“沉默”。
Hello工控
2025/05/21
1960
MQTT Keep Alive 参数有什么用途?
推荐阅读
相关推荐
​MQTT 持久会话与 Clean Session 详解
更多 >
LV.1
这个人很懒,什么都没有留下~
交个朋友
加入HAI高性能应用服务器交流群
探索HAI应用新境界 共享实践心得
加入腾讯云技术交流站
洞悉AI新动向 Get大咖技术交流群
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档