首页 > 其他分享 >mqtt协议

mqtt协议

时间:2022-08-20 18:12:37浏览次数:57  
标签:协议 订阅 MQTT mqtt 消息 服务器 客户端

一  简述

MQTT(消息队列遥测传输协议),是一种基于发布/订阅(publish/subscribe)模式的“轻量级”通讯协议,该协议构建于TCP/IP协议上。MQTT最大优点在于,可以以极少的代码和有限的带宽,为连接远程设备提供实时可靠的消息服务。作为一种低开销,低宽带占用的即时通讯协议,使其在物联网,小型设备,移动应用等方面有效广泛的应用

MQTT是一个基于客户端-服务器的消息发布/订阅传输协议。MQTT协议是轻量,简单,开放和易于实现的。如:机器与机器(M2M)通信和物联网(loT)。

 

二  设计规范

由于物联网的环境是非常特别的,所以MQTT遵循以下设计原则:

1)精简,不添加可有可无的功能

2)发布/订阅(Pub/Sub)模式,方便消息在传感器之间传递

3)允许用户动态创建主题,零运维成本

4)把传输量降到最低以提高传输效率

5)把低带宽,高延迟,不稳定的网络等因素考虑在内

6)支持连续的会话控制

7)理解客户端计算能力可能很低

8)提供服务质量管理

9)假设数据不可知,不强求传输数据的类型与格式,保存灵活性

 

三  MQTT协议原理

3.1 MQTT协议实现方式

实现MQTT协议需要客户端和服务器端通讯完成,在通讯过程中,MQTT协议中有三种身份:发布者(Publish),代理(Broker)(服务器),订阅者(Subscribe)。其中,消息的发布者和订阅者都是客户端,消息代理是服务器,消息发布者可以同时是订阅者

MQTT 传输的消息分为:主题(Topic) 和负载(payload)两部分

  1)Topic,可以理解为消息类型,订阅者订阅(Subscribe)后,就会收到该主题的消息内容(payload);

  2)payload,可以理解为消息的内容,是指订阅者具体要使用的内容

3.2网络传输与应用消息

MQTT会构建底层网络传输:它将建立客户端到服务器的连接,提供两者之间的一个有序的,无损的,基于字节流的双向传输

当应用数据通过MQTT网络发送时,MQTT会把与之相关的服务质量(Qos)和主题名(Topic)相关连

3.3 MQTT客户端

一个使用MQTT协议的应用程序或者设备,它总是建立到服务器的网络连接。客户端可以:

  1)发布其他客户端可能会订阅的信息

  2)订阅其他客户端发布的消息

  3)退订或删除应用程序的消息

  4)断开与服务器连接

3.4 MQTT服务器

MQTT服务器以称为“消息代理”(Broker),可以是一个应用程序或一台设备,它是位于消息发布者和订阅者之间,它可以:

  1)接受来自客户的网络连接;

  2)接受客户发布的应用消息;

  3)处理来自客户端的订阅和退订请求

  4)向订阅的客户转发应用程序消息

3.5 MQTT协议中的订阅,主题,会话

(1)订阅(Subscription)

订阅包含主题筛选器(Topic Filter)和最大服务质量(Qos)。订阅会与一个会话(session)关联。一个会话可以包含多个订阅。每一个会话中的每个订阅都有一个不同的主题筛选器

(2)会话(session)

每个客户端与服务器建立连接后就是一个会话,客户端和服务器之间有状态交互。会话存在一个网络之间,也可能在客户端和服务器之间跨越多个连接的网络连接

(3)主题(Topic Name)

连接到一个应用程序消息的标签,该标签与服务器的订阅匹配。服务器会将消息发送给订阅所匹配标签的每个客户端

(4)主题筛选器(Topic Filter)

一个对主题名通配符筛选器,在订阅表达式中使用,表示订阅所匹配到的多个主题

(5)负载(Payload)

消息订阅者所具体接收的内容

3.6 MQTT协议中的方法

MQTT协议中定义了一些方法(也被称为动作),来表示对确定资源所进行操作。这个资源可以代表预先存在的数据或动态生成数据,这取决于服务器的实现。通常来说,资源指服务器上的文件或输出。主要方法有:

  1)Connect,等待与服务器建立连接

  2)Disconnect,等待MQTT客户端完成所做的工作,并与服务器断开TCP/IP会话

  3)Subscribe,等待完成订阅

  4)UnSubscribe,等待服务器取消客户端的一个或多个topics订阅

  5)Publish,MQTT客户端发送消息请求,发送完成后返回应用程序线程

 

抄的菜鸟教程,抄一遍印象更深刻

标签:协议,订阅,MQTT,mqtt,消息,服务器,客户端
From: https://www.cnblogs.com/xianqingsong/p/16608097.html

相关文章

  • 网络协议:SDP
    本文更新于2022-05-02。SDP(SessionDescriptionProtocol),即会话描述协议。文档见RFC4566:https://datatracker.ietf.org/doc/rfc4566。a(Attributes):属性。用于描述上一......
  • ZAB协议介绍
    什么是Zab协议ZAB协议,全称ZookeeperAtomicBroadcast(Zookeeper原子广播协议)。它是专门为分布式协调服务——Zookeeper,设计的一种支持崩溃恢复和原子广播的协议。从设......
  • 浅谈 Raft 分布式一致性协议|图解 Raft
    前言本篇文章将模拟一个KV数据读写服务,从提供单一节点读写服务,到结合分布式一致性协议(Raft)后,逐步扩展为一个分布式的,满足一致性读写需求的读写服务的过程。其中将配合引......
  • 物联网之Wifi协议
    今天来重点介绍一下WIfi协议,咱们用的其实已经很多了。    主要内容:⼀、基本概述⼆、实践基础三、⼀些原理 ⼀、基本概述============================1......
  • 物联网相关协议
    物联网通信协议,它们具有不同的性能、数据速率、覆盖范围、功率和内存,而且每一种协议都有各自的优点和或多或少的缺点。其中有些通信协议只能用在小型家用电器,而其他一些通......
  • 隐私协议那些事
    隐私协议的告知告知的基本要求《中华人民共和国个人信息保护法》第七条处理个人信息应当遵循公开、透明原则,公开个人信息处理规则,明示处理的目的、方式和范围。这一明......
  • ESP8266 安信可固件 MQTT AT指令
    9.1AT+MQTTUSERCFG-SetMQTTUserConfigSetCommand:AT+MQTTUSERCFG=<LinkID>,<scheme>,<"client_id">,<"username">,<"password">,<cert_key_ID>,<CA_ID>,<"path">A......
  • 个人所得税赡养老人书面分摊协议
    个人所得税赡养老人书面分摊协议被赡养人:____赡养人:____、____、____根据新个税法规定,非独生子女赡养老人专项附加扣除需拟定分摊协议,现针对此规定赡养人做出如下指定分......
  • PLC网口读写上位机调试工具软件 支持欧姆龙fins协议三菱MC协议
    PLC数据采集调试软件  软件资料链接......
  • 2022.34 物联网协议
    物联网的发展离不开互联网,但由于物联网场景复杂多样,设备端硬件规格、网络稳定性、流量限制、功耗等因素造成物联网设备的消息传递与传统互联网场景有着很大不同,也因此产生......