中间件系列——EMQX 快速上手

公众号:技术小厨师

关注小厨师,烹饪美味的技术餐

EMQX 介绍

EMQX 是基于 Erlang/OTP 平台开发的开源物联网 MQTT 消息服务器。而 MQTT 实际上是一种应用层协议,用于实现轻量的、发布订阅式的物联网消息协议。事实上,虽然 EMQX 的定位是物联网消息协议 MQTT 的 broker,但是它的处理能力已经超过了它的定义。而在之后的文章中,我们会为读者介绍使用 EMQX 来实现 IM 的推送系统。

本文受限于篇幅,不介绍 MQTT 协议

安装 EMQX

这里为了方便起见,我们只介绍压缩包安装,也方便利用我们前面所提到的 Centos 集群发布机制,

压缩包安装

首先我们打开下面的网站,

https://www.emqx.com/zh/try?product=broker

然后我们选择我们对应的版本信息,然后下载压缩包即可,下载完成后进行解压即可,

unzip emqx-4.4.2-otp24.1.5-3-el7-amd64.zip

emqx 目录结构如下:

emqx/
├── bin # 可执行文件的位置
├── data # 存放数据的位置
├── dynlibs
├── erts-12.1.5
├── etc # 配置文件位置及插件配置文件位置
├── lib
├── log # 日志存放位置
└── releases

添加到全局环境变量(可选)

如果读者不太了解 Centos 的环境变量怎么配置,则可以使用下面的脚本修改执行即可,

export EMQX_HOME=#读者 EMQX 的安装位置
echo "PATH=\$PATH:$EMQX_HOME\bin" > /etc/profile.d/my_emqx.sh

比如读者的 EMQX 安装位置为 /opt/module/emqx,则对应脚本替换如下,

export EMQX_HOME=/opt/module/emqx
echo "PATH=\$PATH:$EMQX_HOME/bin" > /etc/profile.d/my_emqx.sh

接下来就是让环境变量生效即可,

source /etc/profile

启停命令使用

对于中间件,我们上手的使用方法肯定无非就是启动,停止,重启啦。

如果读者没有添加环境变量,那么之后的执行命令,读者都应该以绝对或者相对路径来指明 emqx 可执行文件的位置,譬如下列命令,

./emqx start
/opt/module/emqx/bin/emqx start

下面我们尝试启动 emqx,

emqx start

启动成功后,应该看到输出包含以下内容,

EMQ X Broker x.x.x is started successfully!

当修改了配置文件或者其他原因需要重新启动 EMQX 时,使用以下命令,

emqx restart

重启成功后,应该看到输出包含以下内容,

EMQ X Broker 4.4.2 is stopped: ok
EMQ X Broker 4.4.2 is started successfully!

如果要停止 emqx,可以使用以下命令,

emqx stop

控制台使用

在启动了 emqx 后,我们可以通过访问 18083 端口来使用控制台,

image-20220404222346716

其默认的账号密码为 admin 和 public。

进入到 EMQX 后,我们可以首先将语言改为中文,

image-20220404222735198

下面我们来介绍一下 EMQX dashboard 的各项功能吧。

  • 监控:查看当前运行节点的各项指标
  • 客户端:查看已经连接的客户端
  • 主题:查看当前活动的主题
  • 订阅:查看当前的客户端与主题的订阅情况
  • 规则引擎:用SQL构建用于消息流的实时处理,本文不做介绍
  • 统计分析:主题的消息流入流出统计信息
  • 插件:这里提供了许多 EMQX 的附加功能,本文后续将会使用其中几个插件
  • 模块
  • 工具:主要包含 EMQX HTTP API 和 WebSocket 即时功能,其中 WebSocket 是一个基于浏览器的 MQTT 客户端工具
  • 告警:用于显示一些威胁到 EMQX 稳定运行的事件,比如主机剩余内存告急,CPU 荷载过高等信息。
  • 通用:这里包含一些用户管理相关功能,一些端口使用的有效信息。

MQTTX 客户端

有了 MQTT broker 还不够,我们还需要一个好用的 MQTT Client,那么这个这里推荐官方提供的客户端 MQTTX,

https://mqttx.app/zh

安装完成后,界面如下所示,使用方法非常简单,点击左侧 + 按钮,即可创建连接,

其连接的高级功能本文不做介绍,里面涉及一些 MQTT 协议的内容,如果读者了解 MQTT 协议,自然理解里面的一些设置的含义。

连接

作者使用它来连接到本地的 192.168.100.100 虚拟机中的 EMQX,

image-20220405014144463

点击连接后,如果连接成功将会显示如下的内容,

image-20220405014447704

订阅与发布

现在我们再创建一个连接,用来测试之后的订阅与发布功能。现在我们两个连接都已经连接上了 EMQX,

image-20220405014810255

我们通过“添加订阅”功能为两个连接添加同一个订阅,

image-20220405015208192

现在我们通过其中一个连接给主题 test- topic 发送消息,

image-20220405015353716

我们可以看到另一个连接接收到了新的消息,

image-20220405015436618

至此有关 MQTTX 的介绍到此为止。

ansystool手写中间件的并行框架是一种用于优化计算过程中并行执行的工具。它基于并行计算的理论和技术,结合了分布式计算、并发编程和并行算法等多种技术手段,旨在提高计算性能和效率。 这个并行框架可以将计算任务划分成多个子任务,然后并行地执行这些子任务,从而加快整个计算过程的速度。它可以根据计算需求的特点和硬件环境的情况,选择合适的并行策略和算法,使得计算任务能够得到有效地分解和并行化。 ansystool手写中间件的并行框架还提供了丰富的并行编程接口和工具,使得开发人员可以方便地利用并行计算资源,编写高效的并行代码。它支持任务调度、数据传输、同步和通信等关键操作,以及任务分配、负载均衡和故障处理等关键功能,保证了整个并行计算过程的正确性和稳定性。 此外,ansystool手写中间件的并行框架还具有良好的可扩展性和灵活性,可以根据计算任务的规模和要求,进行弹性的资源分配和管理。它可以利用现有的计算资源,也可以扩展到多个计算节点或集群,在大规模并行计算场景下,仍然能够保持高效的计算性能和吞吐量。 总之,ansystool手写中间件的并行框架是一种强大的工具,可以帮助开发人员利用并行计算的优势,提高计算性能和效率。它在分布式计算、并发编程和并行算法等领域都具有广泛的应用前景。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值