Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >桥接 Mosquitto MQTT 消息至 EMQX

桥接 Mosquitto MQTT 消息至 EMQX

原创
作者头像
EMQ映云科技
发布于 2022-09-13 02:04:34
发布于 2022-09-13 02:04:34
1.3K0
举报
文章被收录于专栏:EMQ 物联网EMQ 物联网

Mosquitto 是一个小型轻量的开源 MQTT 服务器,由 C/C++ 语言编写,采用单核心单线程架构,支持部署在资源有限的嵌入式设备,接入少量 MQTT 设备终端,并实现了 MQTT 5.0 和 3.1.1版本协议。Mosquitto 完整支持了 MQTT 协议 特性,但基础功能上 Mosquitto 集群功能羸弱,官方和第三方实现的集群方案均难以支撑物联网大规模海量连接的性能需求。

因此 Mosquitto 并不适合用来做规模化服务的 MQTT 服务器,但由于其足够轻量精简,可以运行在任何低功率单片机包括嵌入式传感器、手机设备、嵌入式微处理器上,是物联网边缘消息接入较好的技术选型之一,结合其桥接功能可以实现消息的本地处理与云端透传。

EMQX 是一款大规模分布式物联网 MQTT 消息服务器,可以高效可靠连接海量物联网设备,实时处理分发消息与事件流数据。EMQX 节点可以被其他类型的 MQTT 服务器MQTT 云服务桥接,实现跨平台的消息订阅和发送。本文我们将以一个配置实例来演示如何桥接 Mosquitto MQTT 消息至 EMQX。

场景描述

假设我们有一个 EMQX 服务器集群 emqx1,和一台 Mosquitto 服务器,我们需要在 Mosquitto 上创建一条桥接,把所有传感器主题 sensor/# 消息转发至 emqx1 集群,并从 EMQX 订阅所有控制主题 control/#

EMQX

得益于 EMQX 标准的 MQTT 协议支持,Mosquitto 可以桥接至任意版本的 EMQX,此处使用 EMQX Cloud 提供的 免费的在线 MQTT 服务器 进行测试:

Mosquitto

本文使用的 Mosquitto 版本为 2.0.14,下载安装方式详见 Mosquitto Download

简单的 Mosquitto MQTT 桥接示例

配置 Mosquitto 的桥接需要在安装后修改 mosquitto.conf 文件,对于每一个桥接,需要配置的基本内容有:

  • 远端的 EMQX 服务器的地址和端口
  • MQTT 协议参数,如协议版本,keepalive, clean_session等(如不配置则使用默认值)
  • EMQX 需要的客户端登录信息
  • 需要桥接的消息的主题
  • 配置桥接主题映射(默认无映射)

以下是最终的配置文件,下文会详细讲解每个部分配置的释义:

代码语言:text
AI代码解释
复制
connection emqx1
address broker.emqx.io:1883
bridge_protocol_version mqttv50
remote_clientid emqx_c
remote_username emqx_u
remote_password public
topic sensor/# out 1
topic control/# in 1
新建 MQTT 桥接

打开 mosquitto.conf 文件,在配置文件末尾增加一个 MQTT 桥接配置,使用 emqx1 作为 connection 名称:

代码语言:text
AI代码解释
复制
connection emqx1
配置桥接远端节点的地址和端口
代码语言:css
AI代码解释
复制
address broker.emqx.io:1883
配置 MQTT 协议版本

Mosquitto 桥接使用的 MQTT 协议版本默认为 3.1.1,EMQX 完整支持 MQTT 5.0 特性,此处使用 MQTT 5.0 版本进行桥接:

代码语言:text
AI代码解释
复制
bridge_protocol_version mqttv50
配置远端节点客户端 ID
代码语言:text
AI代码解释
复制
remote_clientid emqx_c
配置远端节点用户名
代码语言:text
AI代码解释
复制
remote_username emqx_u
配置远端节点密码
代码语言:text
AI代码解释
复制
remote_password public
指定需要桥接的 MQTT 主题

桥接主题的配置格式为 topic <topic> [[[out | in | both] qos-level] local-prefix remote-prefix],它定义了桥接转发和接收的规则,其中:

  • <topic>指定了需要桥接的主题,支持通配符
  • 方向可以是 out, in 或者 both
    • out: 将本地主题数据发送到远端 Broker
    • in: 订阅远端 Broker 的主题,将数据发布到本地
    • both: 在同一个主题上进行双向桥接
  • qos-level为桥接的 QoS 级别, 如不指定则使用被转发消息原 QoS
  • local-prefixremote-prefix 对应本地和远程前缀,用于主题映射时在转发和接收的消息主题上加上相应前缀,以便应用可以识别消息来源。

对应本文场景可以添加以下两条桥接规则:

代码语言:text
AI代码解释
复制
topic sensor/# out 1
topic control/# in 1

在配置完成后,需要重新启动 Mosquitto 使 MQTT 桥接配置生效。

配置 EMQX 服务器

使用公共服务器时不需要配置任何参数。实际应用中,为了使 Mosquitto MQTT 消息桥接成功,需要视用户 EMQX 的安全配置情况决定是否配置相应的客户端认证授权信息。

测试配置

我们可以使用 MQTT 客户端工具来测试 MQTT 桥接的配置是否成功,此处使用的是 MQTT X CLI,一款由 EMQ 开发的强大而易用的 MQTT 5.0 命令行工具。

测试桥接的 out 方向

在远程 EMQX 上订阅 sensor/#主题,等待接收 Mosquitto 桥接上报的数据:

代码语言:lua
AI代码解释
复制
mqttx sub -t "sensor/#" -h broker.emqx.io

在本地 Mosquitto 的 sensor/1/temperature 主题上发布消息,该消息将在 Mosquitto 中发布,同时桥接至远程 EMQX:

代码语言:text
AI代码解释
复制
mqttx pub -t "sensor/1/temperature" -m "37.5" -q 1

此时远程 EMQX 应当能收到 Mosquitto 桥接上报的消息:

代码语言:text
AI代码解释
复制
payload:  37.5

测试桥接的 in 方向

在本地 Mosquitto上订阅 control/# 主题,该主题将接收到远程 EMQX 上发布的消息:

代码语言:text
AI代码解释
复制
mqttx sub -t "control/#"

在远程 EMQX 的 control/t/1 主题上发布消息,消息将在 EMQX 集群中传递,同时桥接到 Mosquitto 本地:

代码语言:css
AI代码解释
复制
mqttx pub -t "control/t/1" -m "I'm EMQX" -h broker.emqx.io

此时在 Mosquitto 上应能收到该消息:

代码语言:text
AI代码解释
复制
payload:  I'm EMQX

除了 Mosquitto 外,由 EMQ 开源的超轻量级 MQTT 消息服务器 NanoMQ 同样适用于物联网边缘接入场景,我们将在后续的文章中带来桥接 NanoMQ 消息至 EMQX 的教程。

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

原文链接:https://www.emqx.com/zh/blog/bridging-mosquitto-to-emqx-cluster

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

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

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

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

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
EMQX从搭建到作用于MQTT
​ 1. 协议与实现:MQTT 是一种协议,定义了消息发布、订阅、分发的标准;而 EMQX 是基于此协议实现的消息代理服务。EMQX 支持 MQTT 3.1、3.1.1 和 5.0 版本的协议。
一只牛博
2025/05/31
2340
EMQX从搭建到作用于MQTT
[分享]7 个 MQTT 客户端工具
随着物联网行业的飞速发展,MQTT 协议也被越来越多的公司及开发者所使用。在学习和使用 MQTT 的过程中,一个得心应手的客户端工具可以极大的方便开发者进行 MQTT 特性的探索及物联网应用的调试,缩短开发周期。
科控物联
2023/09/01
23.3K1
[分享]7 个 MQTT 客户端工具
​更强大的 MQTT over QUIC 桥接 & Azure 桥接
金秋十月,NanoMQ 继续保持稳步更新,最新的 0.13 版本将于近日正式发布。此版本的更新继续聚焦于桥接功能部分:为原来的 MQTT over QUIC 桥接功能增加了多路桥接和更丰富的 QUIC 传输层配置参数,新增了内置的 Azure 桥接功能。另外新增了规则引擎消息重发布功能。
EMQ映云科技
2022/11/10
1.3K0
物联网项目:充电桩项目实战~
MQTT,全称Message Queuing Telemetry Transport,即消息MQTT,即消息队列遥测传输,是一种基于客户端-服务器的消息发布/订阅传输协议。这种协议的设计思想是轻量、开放、简单和规范,因此易于实现。
田维常
2023/11/15
1.8K0
物联网项目:充电桩项目实战~
Mosquitto vs NanoMQ | 2023 MQTT Broker 对比
Mosquitto 和 NanoMQ 都是用 C/C++ 开发的快速轻量的开源 MQTT Broker,完全支持 MQTT 3.1.1 和 5.0。
EMQ映云科技
2023/04/23
1.3K0
物联网+mqtt+微信小程序(ESP8266+OneNET+小程序)
这篇文章主要了解ESP8266物联网小程序MQTT远程操控相关内容(ESP8266+OneNET+小程序)
xiao李
2024/04/08
3.2K0
物联网+mqtt+微信小程序(ESP8266+OneNET+小程序)
MQTT 服务器介绍
MQTT 是基于 发布(Publish)/订阅(Subscribe) 模式来进行通信及数据交换的,与 HTTP 的 请求(Request)/应答(Response) 的模式有本质的不同。
全栈程序员站长
2022/08/25
7.3K0
MQTT 服务器介绍
工业物联网数据桥接教程:Modbus 桥接到 MQTT
Modbus 是一种串行通信协议,用于连接工业自动化设备,最初由 Modicon 公司开发,诞生于 1979 年,现在已成为通用的通讯标准之一,广泛用于工业自动化场景。
EMQ映云科技
2023/08/13
1.4K0
工业物联网数据桥接教程:Modbus 桥接到 MQTT
Java使用EMQX实现MQTT通信
在上一篇文章 《Java使用modbus4j实现ModbusTCP通信》 中我们介绍了Java与Modbus协议的TCP通信,本文讲解一下如何用Java实现对当下最流行的物联网协议之一的MQTT协议进行通信。
Jensen_97
2023/07/20
1.7K0
Java使用EMQX实现MQTT通信
MQTT X v1.8.1版本发布:桌面端支持自动更新,MQTT X CLI支持MQTT 5.0
近日,MQTT X 发布了最新的 1.8.1 版本(下载地址:https://github.com/emqx/MQTTX/releases/tag/v1.8.1),MQTT X 桌面端版本已支持自动更新,并对 MQTT X Web 页面进行了优化。目前已完成了 MQTT X CLI 对于 MQTT 5.0 的连接支持及用户属性设置支持,并新增了一个 conn 命令来快速测试连接,后续还将添加 bench 命令,将支持部分场景下的 MQTT 协议性能测试。
EMQ映云科技
2022/08/11
4990
一文搞懂MQTT,如何在SpringBoot中使用MQTT实现消息的订阅和发布
之前介绍了RabbitMQ以及如何在SpringBoot项目中整合使用RabbitMQ,看过的朋友都说写的比较详细,希望再总结一下目前比较流行的MQTT。所以接下来,就来介绍什么MQTT?它在IoT中有着怎样的作用?如何在项目中使用MQTT?
章为忠学架构
2023/10/06
21.8K2
一文搞懂MQTT,如何在SpringBoot中使用MQTT实现消息的订阅和发布
使用 EMQX 和 eKuiper 进行 MQTT 流处理:快速教程
MQTT 协议是一种专为物联网应用而设计的轻量级消息传输协议。它具有简单、开放、易于实现的特点,是物联网应用的理想选择。MQTT 数据以连续实时的方式进行传输,非常适合由流处理引擎进行处理。
EMQ映云科技
2023/07/14
5810
使用 EMQX 和 eKuiper 进行 MQTT 流处理:快速教程
亿级万物互联新时代的物联网消息中间件 EMQX 调研
最近去某餐厅吃饭,进门时智能门自动打开房门同时来一句"欢迎光临",然后伸手到门口的洗手台,水管无接触自动出水,端起菜盘走向台子选择自己喜欢的菜品,最后将菜盘放在智能结账机上,智能结账机通过图形识别算法识别到选了什么菜,然后计算出应该付多少钱,最后小编摘下口罩刷一刷人脸钱就付过去了,整个过程无需其他人的参与,也无需带任何物品包含手机。可能你也已经感受到了,我们身边越来越多的硬件设备正在被嵌入芯片、注入软件,从而实现各种各样的新应用、新功能,比如智能门锁,智能音箱等,前几年炒的火热的智能家居,物联网万物互联等概念,现在正在潜移默化的影响着所有人,了解一些物联网知识对我们了解这个新时代有所帮助。
宋小生
2022/11/28
1.1K0
亿级万物互联新时代的物联网消息中间件 EMQX 调研
初识EMQX与安装
EMQ X 基于 Erlang/OTP 平台开发的 MQTT 消息服务器,是开源社区中最流行的 MQTT 消息服务器。EMQ X 是开源百万级分布式 MQTT 消息服务器(MQTT Messaging Broker),用于支持各种接入标准 MQTT 协议的设备,实现从设备端到服务器端的消息传递,以及从服务器端到设备端的设备控制消息转发。从而实现物联 网设备的数据采集,和对设备的操作和控制。
叫我阿杰好了
2022/11/07
4.7K0
初识EMQX与安装
EMQX vs Mosquitto | 2023 MQTT Broker 对比
物联网开发者需要为自己的物联网项目选择合适的 MQTT 消息产品或服务,从而构建可靠高效的基础数据层,保障上层物联网业务。目前市面上有很多开源的 MQTT 产品,在性能功能等方面各有优点。本文将选取目前最为流行的两个开源 MQTT Broker:EMQX 和 Mosquitto,从技术架构、性能、功能、社区情况等多维度进行 1v1 对比,帮助读者更加深入了解这两个产品。
EMQ映云科技
2023/04/21
3.1K0
EMQX vs NanoMQ | 2023 MQTT Broker 对比
EMQX 和 NanoMQ 都是由全球领先的开源物联网数据基础设施软件供应商 EMQ 开发的开源 MQTT Broker。
EMQ映云科技
2023/04/19
1.5K0
NanoMQ Newsletter 2022-08|v0.11:MQTT 5.0 + MQTT over QUIC 桥接,新增 HTTP API 监控客户端状态
8 月,NanoMQ 继续保持稳步更新。最新的 0.11.0 版本已于 8月底正式发布(https://github.com/emqx/nanomq/releases/tag/0.11.0)。此版本继续增强了桥接功能,增加了 MQTT 5.0 + MQTT over QUIC 桥接模式,新增和修复了对已连接客户端状态进行监控和查询的 HTTP API。此外各项性能优化和缺陷修复也在持续进行中。
EMQ映云科技
2022/09/06
2.4K0
MQTT服务器部署
现在物联网常用的通信方式有哪些?RF433/315M、蓝牙、Zigbee、wifi、以太网等等,通信协议也按不同功能分了许多种,例如TCP、MQTT等,具体可到https://blog.csdn.net/sinat_36098122/article/details/80930168 研究。我当前用的比较多的是MQTT协议,它被较多的用来需要省电的设备通信上,采用发布/订阅的形式传输消息,具体可参考https://www.cnblogs.com/skullboyer/p/9085210.html。 要使用MQTT通信,就少不了MQTT服务器,它是消息传送的中转站(代理)。也就是说MQTT服务器并不存储消息,消息的发布与接收都由客户端完成。我主要写一下目前也是较流行的两者MQTT服务器的搭建:EMQ和Mosquitto。这两种服务器都是开源的,这里写的是部署在windows服务器上的方法(没办法菜鸟只能搞win,以后再玩玩Linux)。
全栈程序员站长
2022/08/24
7K0
MQTT服务器部署
MQTT 协议入门:基础知识和快速教程
本文是 MQTT 协议的入门指南,提供了实用的代码示例。物联网和 MQTT 的初学者可以通过本文掌握 MQTT 的基本概念,快速开启 MQTT 服务和应用的开发。
EMQ映云科技
2023/06/27
1.5K0
MQTT 协议入门:基础知识和快速教程
Java物联网开发(二) —— 开源百万级分布式 MQTT 消息服务器EMQX
Mnesia 数据库是 Erlang 内置的一个分布式 DBMS,可以直接存储 Erlang 的各种数据结构 EMQ X 使用 Mnesia 数据库存储自身运行数据,例如告警记录、规则引擎已创建的资源和规则、Dashbaord用户信息等数据,这些数据都将被存储在 mnesia 目录下,因此一旦删除该目录,将导致 EMQ X 丢失所有业务数据。可以通过 emqx_ctl mnesia 命令查询 EMQ X 中 Mnesia 数据库的系统信息。
时间静止不是简史
2021/08/12
8K0
Java物联网开发(二) —— 开源百万级分布式 MQTT 消息服务器EMQX
推荐阅读
相关推荐
EMQX从搭建到作用于MQTT
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档