MQTT与HTTP的区别
  • HTTP协议是客户端与服务端直连请求与响应
  • MQTT是基于发布订阅模型的轻量级的消息传输协议
MQTT能力
  • 发布:Publish
  • 订阅:Subscribe
  • 代理:Broker,管理通信
  • 执行模式:客户端发送消息到broker,broker将消息发送给订阅过的客户端
MQTT通信模式
  • 一对一:点对点通信
  • 一对多:消息广播
  • 多对一:数据采集
  • MQTT 底层协议基于TCP实现
服务质量等级
  • QoS 0:消息可能丢失 (最多一次传输)
  • QoS 1:消息不会丢失但可能重复 (至少一次传输)
  • Qos 2:消息不会丢失也不会重复 (仅有一次传输)
  • 服务质量越稳定可靠性越高的同时对性能损耗越大
  • 根据实际网络情况和服务质量选择质量等级
心跳机制

KeepAlive是在TCP中一个可以检测死连接的机制,不稳定的网络环境可能会让连接进入假死状态,为了减少对上层的影响,客户端和代理都需要及时感知连接是否处于异常状态,底层tcp协议的KeepAlive感知所需时间太长,mqtt自己定义了一套KeepAlive机制,客户端需要定期发送心跳报文,用来感知异常状态进行断开

心跳是创建连接的时候,在connect报文中指定,指定时间单位是s,假设KeepAlive指定心跳时间为1分钟,当客户端连接空闲时间超过1分钟时,向broker发送心跳报文PINGREQ,broker收到心跳请求后返回心跳响应PINGRESP,如果broker超过1.5分钟时间没有收到心跳请求则断开连接,可以投递遗嘱消息到订阅方,如果客户端超过一定时间没有收到心跳响应也断开连接

  • 遗嘱消息:

    在MQTT中采用发布订阅模式,实际通信的双方不会直接进行连接,所有通信的客户端无法感知对方的在线状态,遗嘱机制就是客户端连接的时候向代理设置自己的遗嘱内容,一旦代理发现连接异常断开,就向所有订阅该遗嘱的客户端发送遗嘱消息

  • 保留消息

    发布一条消息的时候,如果订阅方不在线,就会错过这条消息,如果不想这样可以使用保留消息功能,让broker保留向主题发送的最后一条消息,当订阅端重新上线并订阅的时候,broker就会把消息发送过去,这样可以让客户端上线时就收到消息,保持更新,无需等待下次消息

  • 半开连接:

    当通信双方直接的传输因为网络或者其他原因有时会不同步,比如一方发生崩溃或者传输错误,在tcp中这种不完全连接状态称为半开连接,表象是通信的一侧继续运行,不回通知另一侧的故障,仍然连接的一方继续尝试发送消息并等待响应

  • 客户接管 Take-Over:

    客户端与broker连接异常断开,时间小于心跳断开时间,尝试重新连接broker,在未达到心跳时间的时间内,客户端与broker会有两条连接,

    针对此项mqtt重新连接并执行客户端Take-Over措施:先断开之前的连接再建立新的连接

MQTT报文

MQTT总共定义了14种报文类型,按照功能分类可以分为连接、发布、订阅、心跳四类

  • CONNECT-客户端向代理发起连接:

    • 客户端标识符
    • 用户名
    • 密码
    • 遗嘱消息
  • PUBLISH-客户端向代理发布消息:

    • 主题
    • QoS
    • Payload
  • SUBSCRIBE-客户端向代理订阅的主题:

    • 主题
    • QOS
  • 报文格式:

    1. 固定报头-用于所有控制报文:

    2. 可变报头-部分控制报文

    3. 有效载荷-部分控制报文

MQTT-基础理念的更多相关文章

  1. Flask 框架中 上下文基础理念,包括cookie,session存储方法,requset属性,current_app模块和g模块

    Flask中上下文,分为请求上下文和应用上下文.既状态留存 ,就是把变量存在某一个地方可以调用 请求上下文:实际就是request和session用法理念,既都是可以存储东西. 应用上下文:既变量共享 ...

  2. MQTT基础概念介绍

    https://blog.csdn.net/pipinet123/article/details/60866901 源博客地址:http://blog.csdn.net/pipinet123 MQTT ...

  3. http(一)web和网络基础

    深入学习http不为别的,只为补充底层知识,打好根基,深入了解其他技术,擒贼先擒王,学好九阳神功以后,乾坤大挪移,太极剑就容易了,急于求成,就只能变周芷若.走着...... 来源于:图解HTTP 1. ...

  4. Android Apollo MQTT入门

    一.Apache Apollo服务器其实是一个消息中转站 下载地址 http://activemq.apache.org/apollo/download.html 服务搭建方式,参看博客Android ...

  5. MQTT结构分析

    MQTT,是: 轻量级的消息订阅和发布(publish/subscribe)协议 建立在TCP/IP协议之上 IoT,internet of things,物联网,MQTT在这方面应用较多. 官方网站 ...

  6. 物联网时代-跟着Thingsboard学IOT架构-MQTT设备协议

    Thingsboard的MQTT设备协议 thingsboard官网: https://thingsboard.io/ thingsboard GitHub: https://github.com/t ...

  7. Thingsboard之MQTT设备协议简介

    MQTT基础知识 MQTT是一种轻量级的发布 - 订阅消息传递协议,可能使其最适合各种物联网设备.您可以在此处找到有关MQTT的更多信息.ThingsBoard服务器节点充当MQTT Broker,支 ...

  8. MQTT 协议是个啥?这篇文章告诉你!

    文章首发于我的公众号「程序员cxuan」,欢迎大家关注呀- 说到做到! 之前有位读者给我留言说想要了解一下什么是 MQTT 协议,顺便还把我夸了一把,有点不好意思啦. 那么读者的要求必须要满足啊,所以 ...

  9. 图形数据库Neo4J简介

    最近我在用图形数据库来完成对一个初创项目的支持.在使用过程中觉得这种图形数据库实际上挺有意思的.因此在这里给大家做一个简单的介绍. NoSQL数据库相信大家都听说过.它们常常可以用来处理传统的关系型数 ...

  10. Flume NG Getting Started(Flume NG 新手入门指南)

    Flume NG Getting Started(Flume NG 新手入门指南)翻译 新手入门 Flume NG是什么? 有什么改变? 获得Flume NG 从源码构建 配置 flume-ng全局选 ...

随机推荐

  1. 码农的转型之路-IoTBrowser(物联网浏览器)雏形上线

    消失了半个月闭门造轮子去了,最近干了几件大事: 1.工控盒子,win10系统长时间跑物联网服务测试.运行快2周了,稳定性效果还满意,除了windows自动更新重启了一次. 2 .接触了一些新概念MQT ...

  2. Oracle数据库如何解决创建用户名开头必须要C##问题?

    1.问题 我们在创建用户,概要文件等时,由于使用的是容器数据库,其文件名必须以C##开头. 我们在学习过程中暂时不需要对齐进行区分,所以如何修改这个设定呢? 2.解决 参考链接如何解决创建用户名开头必 ...

  3. 【C++】类成员冒号初始化以及构造函数内赋值

    From:https://blog.csdn.net/zj510/article/details/8135556 通常我们对类成员进行"初始化"有两种方式: 1. 构造函数后面跟冒 ...

  4. Nginx长连接学习之二

    Nginx长连接学习之二 背景 距离最开始学习Nginx的长连接已经一年半; 距离最开始学习Linux的TCP内核参数也已经过去了一年. 最近产品再次出现了TCP链接相关的问题. 因为一开始不知道部署 ...

  5. [转帖]062、监控指标之PD

    PD相关 Grafana 监控 PD -> PD Dashboard 是否存在异常状态的TiKV Grafana 监控 PD -> Region health 大表清理后,出现了大量的空r ...

  6. [转帖]Linux fuse用户态文件系统及其libfuse

    https://www.jianshu.com/p/abc5524ac18c 为什么要有用户态文件系统 VFS文件系统可知文件系统在内核态的,应用程序操作文件,统一调用内核态的VFS层抽象接口. 突然 ...

  7. [转帖] 在Linux上查看活跃线程数与连接数

    https://www.cnblogs.com/codelogs/p/17178675.html   原创:扣钉日记(微信公众号ID:codelogs),欢迎分享,非公众号转载保留此声明. 简介# 现 ...

  8. 【转帖】Docker容器四种网络模式

    https://blog.whsir.com/post-5268.html docker自身默认提供了四种网络模式:none.bridge.container.host.除了这四种网络模式外,还可以通 ...

  9. [转帖]ARM64体系结构编程与实践:基础知识

    ARM64体系结构编程与实践:基础知识 原创 异步社区 2022-03-30 12:44:16 著作权 文章标签 寄存器 体系结构 v8 ARM64体系结构 ARM 文章分类 物联网 阅读数1570 ...

  10. [转帖]nginx 启动、重启、关闭命令详解

    https://www.jianshu.com/p/d70006f18a6d 作者:Gakki nginx 命令详解 输入命令:nginx -h   nginx -h -?,-h:查看帮助 -v:显示 ...