4fe186838ffdbd6713f446c83bfdafa4.gif

1 EMQ介绍

EMQ (Erlang/Enterprise/Elastic MQTT Broker) 是基于 Erlang/OTP 平台开发的开源物联网 MQTT 消息服务器。Erlang/OTP 是出色的软实时(Soft-Realtime)、低延时(Low-Latency)、分布式(Distributed) 的语言平台。MQTT 是轻量的(Lightweight)、发布订阅模式(PubSub) 的物联网消息协议

EMQ 项目设计目标是承载移动终端或物联网终端海量 MQTT 连接,并实现在海量物联网设备间快速低延时消息路由:

  • 稳定承载大规模的 MQTT 客户端连接,单服务器节点支持50万到100万连接。
  • 分布式节点集群,快速低延时的消息路由,单集群支持1000万规模的路由。
  • 消息服务器内扩展,支持定制多种认证方式、高效存储消息到后端数据库。
  • 完整物联网协议支持,MQTT、MQTT-SN、CoAP、WebSocket 或私有协议支持。

EMQ官网:https://www.emqx.io/cn

2 准备工作

搭建MQTT服务器之前,需要先下载EMQ软件包,个人使用选择EMQ X Broker,EMQ X Broker 是基于高并发的 Erlang/OTP 语言平台开发,支持百万级连接和分布式集群架构,发布订阅模式的开源 MQTT 消息服务器

进入官网下载:https://www.emqx.io/cn/downloads#broker

选择版本,软件包,笔者下载的是V2.3.11,软件包选择Window,Window10的压缩包

a7d69d273059534dacd640036b9ec3bd.png

下载完成解压,打开emqttd文件夹,软件包里即包含如下文件(注意:EMQ的下载存放路径别有中文):

c926d9ee67c1a6794f571f0c80f5c595.png

EMQ 2.0用户手册:https://docs.emqx.net/broker/v2/cn/

3 安装EMQ

使用管理员身份运行cmd命令窗口,跳转到emqttd的存放路径下/bin文件夹路径

efde0f5afbc254d708eba89a226eeb24.png

输入命令 emqttd install ,安装emq

e486e97300d8f68fe69cf7f151bd1661.png

输入命令 emqttd start ,启动emq,第一次安装启动emq时可能会卡住,没关系,关闭命令窗口,再次启动emq,当出现以下界面时候即表示已成功启动emq

f308145403caaf6cebfacfdc8e9548aa.png

EMQ 消息服务器启动后,会默认加载 Dashboard 插件,启动 Web 管理控制台。可通过 Web 控制台,查看服务器运行状态、统计数据、客户端(Client)、会话(Session)、主题(Topic)、订阅(Subscription)、插件(Plugin)。

控制台地址: http://127.0.0.1:18083,默认用户: admin,密码:public

尝试登录控制台,验证 EMQ 是否成功启动

7570a153128730bbc1b51970a4d0284c.png
59e5ed7ce9019e4c1839b8b112cf2da3.png

能进入控制台,即表示EMQ安装成功

4 添加用户

EMQ 2.0 支持丰富的扩展插件,包括控制台、扩展模块、多种认证方式、多种接入协议等:2f8909f276fcbac5a18f83d3efc001a7.png

可以在 Web 控制台查看各个插件的运行情况:01b49a87dd108fa6df1d1a298f3ac848.png

用户名、密码认证插件(emq_auth_username)默认是停止运行的,我们需要将其更改为启动d6412ff9790c7514765296eb80d21d8c.png

在命令行窗口使用 emqttd_ctl users add   命令添加用户,添加一个用户名和密码均为test的用户做MQTT测试,可使用命令 emqttd_ctl users list 查看用户列表验证是否成功添加用户

ae3f7f072ef13ce21af7063639bfe46b.png

4 数据交互测试

4.1 MQTTBox连接

使用MQTTBox工具测试 EMQ MQTT服务器是否能正常通信,自定义发布主题和订阅主题,得到MQTTBox连接信息如下:

连接信息 参数
地址 127.0.0.1
端口 1883
用户名 test
密码 test
发布主题 publish_test
订阅主题 subscribe_test
147341e666878addd1f85f8531fb6cb5.png
8f0cfe8977383636a867d15c04827876.png

MQTTBox连接上EMQ MQTT服务器,且订阅subscribe_test主题

4.2  Websocket 连接

EMQ 2.0 消息服务器默认占用的 TCP 端口包括:

端口 用途
1883 MQTT 协议端口
8883 MQTT/SSL 端口
8083 MQTT/WebSocket 端口
8080 HTTP API 端口
18083 Dashboard 管理控制台端口

故我们用WebSocket做MQTT连接时端口应该为8083,而不是1883,故得到WebSocket连接信息如下:

连接信息 参数
地址 127.0.0.1
端口 8083
用户名 test
密码 test
发布主题 subscribe_test
订阅主题 publish_test
4c55c850cebc5d9821d1871dbc02d7bd.png

WebSocket连接上EMQ MQTT服务器,且订阅publish_test主题

4.3 信息交互测试

  • MQTTBox发布一条主题为publish_test的消息,可以在EMQ WebSocket上看到发布的消息

    55d4e452fc2cd59aa698bd74b3323b30.png
    1eb0419ef02e92b0620c4298d9748574.png
  • WebSocket发布一条主题为subscribe_test的消息,可以在MQTTBox上看到发布的消息

    879cce5b1c4a4fb9ce7595cbe67e5cab.png
    67d52444f4d17360df77c884e6e8a7cf.png

    EMQ MQTT服务器能正常接收、发送数据,正常通信,使用EMQ搭建MQTT服务器成功

注意:此处搭建的MQTT服务器只能使用局域网通信进行数据传输

好文分享

  • C语言面试每日一题:static 关键字
  • 物联网--MQTT协议(九):构建PUBLISH报文
  • 物联网基础:EC20 连接阿里云进行数据收发

笔者知识有限,如果发现本文有错误的地方欢迎批评、指正,若本文对您有所帮助,转发、分享也是笔者坚持的动力

ecb47c4da81299cd51af38d541dfb794.gif

f176074800b3fcd416a598a343565efb.gif

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐