MQTT:物联网消息传递标准

简介

MQTT是用于物联网(IoT)的OASIS标准消息传递协议。它被设计为一种非常轻量级的发布/订阅消息传送,非常适合以较小的代码占用量和最小的网络带宽连接远程设备。如今,MQTT被广泛用于汽车,制造业,电信,石油和天然气等行业。

MQ?

“ MQ”是指MQ系列,这是IBM为支持MQ遥测传输而开发的产品。当Andy和Arlen在1999年创建协议时,他们以IBM产品的名字命名。许多来源错误地将MQTT标记为消息队列协议。那明显是错的,MQTT并不是传统的消息排队解决方案。

为什么选择MQTT?

  • 轻巧高效:MQTT客户端非常小,需要最少的资源,因此可以在小型微控制器上使用。MQTT消息头很小以优化网络带宽。
  • 双向通讯:MQTT允许设备到云之间以及云到设备之间的消息传递。这使得易于将消息广播到事物组。
  • 扩展到数百万个事物:MQTT可以扩展以与数百万个IoT设备连接。
  • 可靠的消息传递:对于许多物联网用例而言,消息传递的可靠性至关重要。这就是MQTT具有3种定义的服务质量级别的原因:0-最多一次,1-至少一次,2-恰好一次
  • 对不可靠网络的支持:许多物联网设备通过不可靠的蜂窝网络进行连接。MQTT对持久性会话的支持减少了将客户端与代理重新连接的时间。
  • 安全启用:MQTT使您可以轻松地使用TLS加密消息并使用现代身份验证协议(例如OAuth)对客户端进行身份验证。

MQTT发布/订阅架构

MQTT的使用

说了这么多,MQTT只是一种协议应该怎么使用呢?简单的看分为两个部分:服务端、客户端。接下来,我们利用EMQ作为服务端,MQTT.fx作为客户端,来简单走一遍。

EMQ的安装

  • 这里我使用的时阿里ECS云主机,系统时CentOS。
  • 需要开通安全组:18083、1883
  • 进入CentOS界面输入以下命令:
wget https://packages.emqx.io/emqx-ce/v2.3.10/emqttd-centos7-v2.3.10.zip	//下载安装
yum install unzip -y //安装压缩包
unzip emqttd-centos7-v2.3.10.zip //解压服务器的压缩包
cd emqttd //进入emqtt文件夹
./bin/emqttd console
CTRL+c //关闭控制台
./bin/emqttd start //守护进程模式启动,启动错误日志将输出在 log/ 目录
./bin/emqttd_ctl status //EMQ 消息服务器进程状态查询
  • 登陆MQTT的后台:
服务ip+18083端口,如:192.168.2.100:18083
账号:admin 密码:public

### MQTT.fx客户端安装
- 这里我使用的时win10系统,[去下载]("http://mqttfx.jensd.de/index.php/download")
- 安装完成后出现如下界面:

- 点击 `Extras` - `Edit Connection Profiles` 来编辑:

- 配置你的服务端ip,输入用户名和密码:admin, public:

- 配置完成后,点击 `Connect` 连接,右边的指示灯变录说明连接成功。如果没有请检查你的ip和端口,以及阿里安全组是否开通:

- 切换到 `Subscribe` 输入一个topic,然后来订阅它:

- 切换到 `Publish`,输入topic和要发送的内容,点击 `Publish` 来发布:

- 回到 `Subscribe` 可以看到发布的消息了:

## 参考资料

https://www.hivemq.com/blog/mqtt-essentials-part-1-introducing-mqtt/

https://www.emqx.io/cn/products/enterprise

http://mqttfx.jensd.de/index.php/download

MQTT的使用一的更多相关文章

  1. 海鑫智圣:物联网漫谈之MQTT协议

    什么是MQTT协议 MQTT(消息队列遥测传输协议)是IBM在1999年专门针对物联网等应用场景来制订的轻量级双向消息传输协议,它主要是为了解决物联网上使用到的设备的互相通信的问题,以及这些设备与后端 ...

  2. 几个MQTT的知识点

    开始正文前需要感谢一下网友“小龙”和emqtt.io群里的网友们的帮助,本人刚刚开始使用MQTT有很多不懂的地方,在emqtt.io群里询问解决方法的时候,“小龙”给我详细的讲解了一些MQTT的知识点 ...

  3. 基于MQTT协议进行应用开发

    官方协议有句如下的话来形容MQTT的设计思想: "It is designed for connections with remote locations where a "sma ...

  4. MQTT(三)-----连接与心跳

    MQTT协议笔记之连接和心跳 - 推酷 http://www.tuicool.com/articles/AFvmee 互联网推送服务原理:长连接+心跳机制(MQTT协议) - clh604的专栏 - ...

  5. Mosquitto搭建Android推送服务(一)MQTT简介

    总体概要: MQTT系列文章分为4部分 1.MQTT简介 2.mosquitto服务器搭建 3.编写Mosquitto的可视化工具 4.使用Mosquitto完成Android推送服务 文章钢要: 对 ...

  6. 【开源】MQTT推送服务器——zer0MqttServer(Java编写)

    目录 说明 功能 如何使用 参考帮助 说明 重要的放前面:V1.0版本是一个非常基础的版本,除了完整的MQTT协议实现外,其他功能什么都没做. MQTT 协议是 IBM 开发的即时通讯协议,相对于 I ...

  7. TCP/IP, WebSocket 和 MQTT

    按照OSI网络分层模型,IP是网络层协议,TCP是传输层协议,而HTTP和MQTT是应用层的协议.在这三者之间, TCP是HTTP和MQTT底层的协议.大家对HTTP很熟悉,这里简要介绍下MQTT.M ...

  8. 云巴:基于MQTT协议的实时通信编程模型

    概要 有人常问,云巴实时通信系统到底提供了一种怎样的服务,与其他提供推送或 IM 服务的厂商有何本质区别.其实,从技术角度分析,云巴与其它同类厂商都是面向开发者的通信服务,宏观的编程模型都是大同小异, ...

  9. MQTT 消息 发布 订阅

    当连接向一个mqtt服务器时,clientId必须是唯一的.设置一样,导致client.setCallback总是走到 connectionLost回调.报connection reset.调查一天才 ...

  10. MQTT开发笔记之《MQTT Server》

    MQTT SERVER 性能测试报告 : http://w3yyb.sinaapp.com/archives/1601各个MQTT SERVER功能列表: http://blog.lenix.xyz/ ...

随机推荐

  1. Refresh 重构(Refactor)

    最近在闲暇之余重(第)温(一..次)此书, 首先能感受到的, 无论你是新程序员还是老程序员, 这本书都已经不具备太多的可读性了. 由于本书成书年代久远, 那个时候软件行业还不够发达, 面向对象还没有被 ...

  2. #模型转换,动态规划#洛谷 1758 [NOI2009] 管道取珠

    题目 分析 考虑每种情况的方案数平方之和,可以被转换成有两个人同时独立进行该游戏,问最后情况相同的方案数. 那么设 \(dp[i][j][k][o]\) 表示第一个人在上管道拿了 \(i\) 个,下管 ...

  3. #欧拉函数#洛谷 2303 [SDOI2012] Longge 的问题

    题目 求\(\sum_{i=1}^n\gcd(n,i)\) 分析 \(=\sum_{i=1}^n\sum_{d|gcd(n,i)}\varphi(d)\) \(=\sum_{d|n}\varphi(d ...

  4. RestTemplate进行https请求时适配信任证书

    转载请注明出处: 1.http协议请求 使用RestTemplate进行http协议的请求时,不需要考虑证书验证相关问题,以下为使用RestTemplate直接使用的代码示例: import org. ...

  5. 【Python3.10.4】Centos7 ,centos8,centos9源码安装 python3.10.4 解释器

    1.检查是否安装wget如果没有安装则: 终端执行: yum -y install wget 2.下载python3源码包 终端执行: wget https://www.python.org/ftp/ ...

  6. node require的循环引用是怎么一回事

    require 运行过程 require 引用是同步的,没有异步这么一说,它会先运行一遍. setouttime(function(){ export=a; }) 如果我们require的时候,那么这 ...

  7. Object类的派生-c++

    /* * @Issue: 生成一个Object抽象类 * @Author: 一届书生 * @LastEditTime: 2020-02-24 10:34:13 */ #include<iostr ...

  8. redis命令和lua实现分布式锁

    Redis分布式锁关键 SETNX 语法: SETNX key value 如果key不存在,则存储(key:value)值,返回1 如果key已经不存在,则不执行操作,返回0 因为这个命令的性质,多 ...

  9. Hadoop HDFS 3.2的部署

    之前写过HDFS 2.6的部署,最近项目中尝试使用最新的HDFS 3.2.1做离线存储,部署方式略有不同,所以这里再简单写一下,这里只涉及到存储因此不再配置yarn,只配置HDFS最基本的服务Name ...

  10. 飞桨PaddlePaddle的安装

    飞桨PaddlePaddle的安装 MacOS 下的 PIP 安装 一.环境准备 1.1 如何查看您的环境 可以使用以下命令查看本机的操作系统和位数信息: uname -m && ca ...