echolevan / emqx_plugin_kafka

EMQ X Bridge to Kafka Broker based on EMQ X Broker v4.3. 适配emqx v4.3版本的kafka插件

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

适配emqx v4.3版本

emqx-plugin-template

emqx/emqx-plugin-template at emqx-v4 (github.com) This is a template plugin for the EMQ X broker.

Plugin Config

Each plugin should have a 'etc/{plugin_name}.conf|config' file to store application config.

Authentication and ACL

emqx:hook('client.authenticate', fun ?MODULE:on_client_authenticate/3, [Env]).
emqx:hook('client.check_acl', fun ?MODULE:on_client_check_acl/5, [Env]).

Build the EMQX broker

1. 基于CentOS7.5环境下编译,先安装相关插件
  yum -y install make gcc gcc-c++ glibc-devel glibc-headers kernel-devel kernel-headers m4 ncurses ncurses-devel openssl openssl-devel openssl-libs zlib zlib-devel libselinux-devel xmlto perl git wget
  
  注意:openssl的版本不是1.1.1k,则需要通过源码openssl-1.1.1k.tar.gz来安装openssl
2. 准备Erlang/OTP R21及以上环境

注:由于本插件引用的第三方依赖ekaf中使用了pg2模块,该模块在OTP 24及之后的版本已被官方移除,因此请使用OTP 24以下的版本

参照Erlang and Elixir Packages Download - Erlang Solutions (erlang-solutions.com) 官网安装方式。

3. 下载EMQX源码

官方源码仓库地址为emqx/emqx: An Open-Source, Cloud-Native, Distributed MQTT Message Broker for IoT. (github.com) ,分支为main-v4.3

本人修改了官方的编译脚本,并且在插件目录里添加了该kafka插件的信息,仓库地址为ULTRAKID/emqx at main-v4.3 (github.com) ,分支为main-v4.3

4. 修改EMQX文件,增加kafka插件

参照emqx/README.md at main-v4.3 · ULTRAKID/emqx (github.com)

注:ULTRAKID/emqx at main-v4.3 (github.com) 仓库内已进行此项修改。

5. 编译EMQX,并且启动EMQX

进入emqx目录,执行make命令,需要保持外网通畅,有条件建议科学上网。

二进制编译命令:make

docker镜像打包:make emqx-docker

License

Apache License Version 2.0

Author

EMQ X Team.

About

EMQ X Bridge to Kafka Broker based on EMQ X Broker v4.3. 适配emqx v4.3版本的kafka插件

License:Apache License 2.0


Languages

Language:Erlang 98.4%Language:Makefile 1.6%