源码编译安装EMQX V3.0服务器(MQTT)

2024-05-05 06:48

本文主要是介绍源码编译安装EMQX V3.0服务器(MQTT),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

 

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

  • 稳定承载大规模的 MQTT 客户端连接,单服务器节点支持50万到100万连接。

  • 分布式节点集群,快速低延时的消息路由,单集群支持1000万规模的路由。

  • 消息服务器内扩展,支持定制多种认证方式、高效存储消息到后端数据库。

  • 完整物联网协议支持,MQTT、MQTT-SN、CoAP、WebSocket 或私有协议支持。


 

文章摘要

本篇文章介绍源码编译安装EMQX,后续需要搭配自定义插件将mqtt消息转发到Kafka消息中间件里。

 

我们选择EMQX 开源版,如果要将消息持久化到Kafka里(收费的企业版里支持),需要自行编写插件,幸好Github有开源的kafka插件,我们找V3的一个稳定版本以便能适配kafka插件(目前还没适配3.1或更高版本),因此我们选择3.0.1版本,我们编译安装这个版本。

 

安装Erlang

EMQ 消息服务器基于 Erlang/OTP 平台开发,源码编译依赖 Erlang 环境。EMQX 3.0 依赖Erlang 21.3 版本。

yum install gcc* glibc-devel makencurses-devel openssl-devel autoconf -y
yum install unixODBC unixODBC-devel-y
yum -y install gcc-c++ kernel-develm4 python-simplejson

下载安装包(注意版本号21.3)

wget http://erlang.org/download/otp_src_21.3.tar.gz(80几M,下载很慢)
tar -zxvf otp_src_21.3.tar.gz
cd otp_src_21.3
./otp_build autoconf
(带上ssl模块)
./configure --enable-smp-support--enable-threads --enable-sctp --enable-kernel-poll --enable-hipe --with-ssl
make && make install

erlang 默认安装路径 /usr/local/lib/erlang,验证版本:

 

erl

返回:

Erlang/OTP 21 [erts-10.3] [source][64-bit] [smp:4:4] [ds:4:4:10] [async-threads:1] [hipe]
Eshell V10.3  (abort with ^G)

 

注意,如果之前安装过不同的Erlang版本,安装新版本之前,需要先把老版本的安装目录/usr/local/lib/erlang删除之后再安装新版本,不然安装其他软件时会报编译版本错误。

 

 

安装Rebar(Erlang开发构建工具)

安装依赖rebar(注意rebar3是另外的新版本)

git clonegit://github.com/rebar/rebar.git
cd rebar
./bootstrap

安装成功

==> rebar (compile)
==> rebar (escriptize)
Congratulations! You now have aself-contained script called "rebar" in
your current working directory. Placethis script anywhere in your path
and you can use rebar to buildOTP-compliant apps.

配置环境变量

vi /etc/profile
export PATH=/emq/rebar/:$PATH (rebar安装目录)

执行文件:

source /etc/profile

测试是否安装成功

rebar -V

若出现如下提示,则证明安装成功

rebar 2.6.4 22 20190625_031823 git2.6.4-39-gb6d3094

 

如果安装rebar3,可能有错误:

/emq/rebar3/_build/default/lib/erlware_commons/src/ec_plists.erl:834:Warning: erlang:get_stacktrace/0: deprecated; use the new try/catch syntax forretrieving the stack backtrace
/emq/rebar3/_build/default/lib/erlware_commons/src/ec_plists.erl:836:Warning: erlang:get_stacktrace/0: deprecated; use the new try/catch syntax forretrieving the stack backtrace

解决方法:

使用https://github.com/ferd/erlware_commons/blob/ad2d57d8b62b86ec1f3d03441f7defa595f2c59c/src/ec_plists.erl替换ec_plists.erl文件。

 

 

安装EMQX 3.0.1

mkdir /emq
cd /emq
wget -c https://github.com/emqx/emqx-rel/archive/v3.0.1.tar.gz
tar -zxvf v3.0.1.tar.gz
mv emqx-rel-3.0.1 emqx-rel
cd emqx-rel/
make(编译,很慢;可以先把下面的kafka插件增加进来后,再回到这里编译)

编译成功,返回:

===> Starting relx build process...
===> Resolving OTP Applicationsfrom directories:/emq/emqx-rel/deps/usr/local/lib/erlang/lib/emq/emqx-rel/apps
===> Resolved emqx-3.0.1
===> Including Erts from/usr/local/lib/erlang
===> release successfully created!

 

启动 EMQ X

cd _rel/emqx/bin
./emqx start  启动./emqx_ctl status  状态

EMQX配置文件

/emq/emqx-rel/_rel/emqx/etc/emqx.conf
#关闭匿名认证
mqtt.allow_anonymous = false
#Erlang Process Limit
node.process_limit = 2097152
#Sets the maximum number ofsimultaneously existing ports for this system
node.max_ports = 1048576

 

好了,到这里 源码编译安装 EMQX 3.0.1 就完成了。

这篇关于源码编译安装EMQX V3.0服务器(MQTT)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/961045

相关文章

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作

Java MQTT实战应用

《JavaMQTT实战应用》本文详解MQTT协议,涵盖其发布/订阅机制、低功耗高效特性、三种服务质量等级(QoS0/1/2),以及客户端、代理、主题的核心概念,最后提供Linux部署教程、Sprin... 目录一、MQTT协议二、MQTT优点三、三种服务质量等级四、客户端、代理、主题1. 客户端(Clien

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

mysql中的服务器架构详解

《mysql中的服务器架构详解》:本文主要介绍mysql中的服务器架构,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、mysql服务器架构解释3、总结1、背景简单理解一下mysqphpl的服务器架构。2、mysjsql服务器架构解释mysql的架

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

在Windows上使用qemu安装ubuntu24.04服务器的详细指南

《在Windows上使用qemu安装ubuntu24.04服务器的详细指南》本文介绍了在Windows上使用QEMU安装Ubuntu24.04的全流程:安装QEMU、准备ISO镜像、创建虚拟磁盘、配置... 目录1. 安装QEMU环境2. 准备Ubuntu 24.04镜像3. 启动QEMU安装Ubuntu4

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/