MQTT 消息队列遥测传输

MQTT 消息队列遥测传输

  • Message Queuing Telemetry Transport 是一种轻量级的消息传输协议,基于发布/订阅(Publish/Subscribe)模式,专为低带宽、高延迟或不稳定网络环境设计,支持设备间高效通信,广泛应用于 IoT 物联网(智能家居、环境监测、车联网)、实时推送、聊天软件、远程医疗监控和智慧城市等领域
  • MQTT 是基于 TCP 的应用层协议,是一种基于二进制的协议
  • 轻量级:消息头小,充分利用网络带宽
  • 高效可靠:支持一对多消息传递,很容易实现消息广播到大规模物联网设备群,提供消息传输 QoS 服务质量管理、支持 Keep Alive 心跳机制
  • 安全性:利用 TLS/SSL 加密保障数据传输的安全性
  • 解耦特性:发布者发送消息到特定主题,订阅者订阅感兴趣的主题以接收消息,相互之间感知不到对方的存在,实现解耦通信
  • Retained 保留消息:代理存储发布到主题的最后一条消息,并将其转发给新订阅者,确保新订阅者接收主题的最新状态
  • LWT(Last Will and Testament)遗嘱消息:设备意外断开连接时,代理服务器会发布预设的遗嘱消息,用于通知其他设备状态异常

发布/订阅模式

  • Publisher 发布者(客户端):发送消息到主题,消息的发布者也可以同时是订阅者
  • Subscriber 订阅者(客户端):接收特定主题的消息
  • Broker 代理(消息服务器):作为中间节点(消息中转站),负责接收消息并分发给订阅者
  • Topic 主题(消息的类型):用于标识消息的类别,主题可以是多层次的,使用斜杠分隔,支持通配符订阅
  • Payload 消息:发送消息的数据内容

QoS 服务质量

QoS 0 最多一次:消息可能丢失,但不会重复 QoS 1 至少一次:确保消息到达,但可能重复 QoS 2 正好一次:确保消息只到达一次(最可靠但开销最大)

常见 MQTT Broker

  • Eclipse Mosquitto
  • Apache ActiveMQ
  • EMQX
  • HiveMQ

常见 MQTT Java Client

  • Eclipse Paho Java
  • ActiveMQ Client
相关推荐
不做菜鸟的网工1 小时前
H3C IPv6 over IPv4隧道实验
网络协议
袁小皮皮不皮1 小时前
【HCIA】第三章TCP/IP协议栈中其他主要协议
运维·服务器·网络·网络协议·tcp/ip
小庄梦蝶2 小时前
Mixed Content: The page at ‘https://域名/‘ was loaded over HTTPS
网络协议·http·https
SVIP111592 小时前
Vue3 WebSocket 封装通关指南:心跳 + 重连 + 全局状态管理,复制即用!
网络·websocket·网络协议
taxunjishu2 小时前
MODBUS TCP转Profinet 家纺织造塔讯物联网网关应用实操案例
物联网·网络协议·tcp/ip
-Excalibur-2 小时前
IP数据包在计算机网络传输的全过程
java·网络·c++·笔记·python·网络协议·智能路由器
历程里程碑3 小时前
41 .UDP -3 群聊功能实现:线程池助力多客户端通信
linux·开发语言·网络·数据结构·c++·网络协议·udp
ALex_zry3 小时前
通用RPC跨平台方案设计
网络·网络协议·rpc
LCMICRO-133108477467 小时前
长芯微LD9689完全P2P替代AD9689,是一款双通道、14位、2.0 GSPS/2.6 GSPS模数转换器(ADC)
网络·单片机·嵌入式硬件·网络协议·fpga开发·硬件工程·高速adc
皙然15 小时前
深入理解TCP流量控制
网络·网络协议·tcp/ip