create emqx project

JianBo He 729ca4e1df Merge pull request #7000 from HJianBo/update-dashboard-vsn %!s(int64=4) %!d(string=hai) anos
.ci 1b3b2c0d03 feat: add eval-erl command to `bin/emqx` %!s(int64=4) %!d(string=hai) anos
.github 17599432d1 feat(license): add license application %!s(int64=4) %!d(string=hai) anos
apps 1413809b81 Merge pull request #6948 from zhongwencool/fix-watermark-master %!s(int64=4) %!d(string=hai) anos
bin eea217093b fix(mix): include `node_dump` in tgz and packages %!s(int64=4) %!d(string=hai) anos
deploy 803a4b7020 fix(README): remove extra architectures %!s(int64=4) %!d(string=hai) anos
lib-ee fc8eeb8819 fix(emqx_license): raise throw exception instead of error %!s(int64=4) %!d(string=hai) anos
rel 17599432d1 feat(license): add license application %!s(int64=4) %!d(string=hai) anos
scripts 525bf47618 chore(buildx.sh): set bash -x option after help message %!s(int64=4) %!d(string=hai) anos
.editorconfig 7f12db0180 add editorconfig for emqx %!s(int64=7) %!d(string=hai) anos
.formatter.exs c14e8db869 style(format): format elixir files %!s(int64=4) %!d(string=hai) anos
.gitattributes 39d60121d1 chore: ensure lf but not crlf for build scripts %!s(int64=4) %!d(string=hai) anos
.gitignore 632be78100 fix: gitignore was not properly ignoring rendered configuration files %!s(int64=4) %!d(string=hai) anos
.tool-versions 506dad169a chore(elixir_otp): bump emqx-builder images %!s(int64=4) %!d(string=hai) anos
APL.txt 7f49934216 chore: add BSL.txt %!s(int64=4) %!d(string=hai) anos
CONTRIBUTING.md 56e2a9741f style: ensure newline at EOF for all files %!s(int64=4) %!d(string=hai) anos
LICENSE 7f49934216 chore: add BSL.txt %!s(int64=4) %!d(string=hai) anos
Makefile c6c6b7af89 chore: upgrade dashboard to v0.19.0 %!s(int64=4) %!d(string=hai) anos
NOTICE 9f7b513a3f chore: fix copyright update script to include more files %!s(int64=4) %!d(string=hai) anos
PLUGIN.md 4d9b4cb828 refactor: delete lib-extra %!s(int64=4) %!d(string=hai) anos
README-CN.md fa08722447 chore(README): modify some badges %!s(int64=4) %!d(string=hai) anos
README-JP.md fa08722447 chore(README): modify some badges %!s(int64=4) %!d(string=hai) anos
README-RU.md fa08722447 chore(README): modify some badges %!s(int64=4) %!d(string=hai) anos
README.md 62957bea9d Update README.md %!s(int64=4) %!d(string=hai) anos
Windows.md fc92e4c8bf docs: fix typos %!s(int64=4) %!d(string=hai) anos
build 9021b7e9b8 fix(mix): set enterprise compile flag %!s(int64=4) %!d(string=hai) anos
elvis.config 071c2c99e8 refactor(authn resources): add `emqx_resource` and `emqx_authn` tests %!s(int64=4) %!d(string=hai) anos
mix.exs 8d5241b1d0 chore(system_monitor): Bump version to 3.0.2 %!s(int64=4) %!d(string=hai) anos
pkg-vsn.sh 391e480824 build: parameterise package version %!s(int64=4) %!d(string=hai) anos
rebar.config 8d5241b1d0 chore(system_monitor): Bump version to 3.0.2 %!s(int64=4) %!d(string=hai) anos
rebar.config.erl 5a1b18ae86 fix(system_monitor): Fix conditional start %!s(int64=4) %!d(string=hai) anos

README-CN.md

EMQ X Broker

GitHub Release Build Status Coverage Status Docker Pulls Slack Discord Twitter Community YouTube

最棒的物联网 MQTT 开源团队期待您的加入

English | 简体中文 | 日本語 | русский

EMQ X 是一款完全开源,高度可伸缩,高可用的分布式 MQTT 消息服务器,适用于 IoT、M2M 和移动应用程序,可处理千万级别的并发客户端。

从 3.0 版本开始,EMQ X 完整支持 MQTT V5.0 协议规范,向下兼容 MQTT V3.1 和 V3.1.1,并支持 MQTT-SN、CoAP、LwM2M、WebSocket 和 STOMP 等通信协议。EMQ X 3.0 单集群可支持千万级别的 MQTT 并发连接。

安装

EMQ X 是跨平台的,支持 Linux、Unix、macOS 以及 Windows。这意味着 EMQ X 可以部署在 x86_64 架构的服务器上,也可以部署在 Raspberry Pi 这样的 ARM 设备上。

Windows 上编译和运行 EMQ X 的详情参考:Windows.md

EMQ X Docker 镜像安装

docker run -d --name emqx -p 1883:1883 -p 8081:8081 -p 8083:8083 -p 8883:8883 -p 8084:8084 -p 18083:18083 emqx/emqx

二进制软件包安装

需从 EMQ X 下载 页面获取相应操作系统的二进制软件包。

从源码构建

3.0 版本开始,构建 EMQ X 需要 Erlang/OTP R21+。

4.3 及以后的版本:

git clone https://github.com/emqx/emqx.git
cd emqx
make
_build/emqx/rel/emqx/bin/emqx console

对于 4.3 之前的版本,通过另外一个仓库构建:

git clone https://github.com/emqx/emqx-rel.git
cd emqx-rel
make
_build/emqx/rel/emqx/bin/emqx console

快速入门

如果 emqx 从源码编译,cd _build/emqx/rel/emqx。 如果 emqx 通过 zip 包安装,则切换到 emqx 的根目录。

# Start emqx
./bin/emqx start

# Check Status
./bin/emqx_ctl status

# Stop emqx
./bin/emqx stop

EMQ X 启动,可以使用浏览器访问 http://localhost:18083 来查看 Dashboard。

测试

执行所有测试

make eunit ct

执行部分应用的 common tests

make apps/emqx_retainer-ct

静态分析(Dialyzer)

分析所有应用程序
make dialyzer
要分析特定的应用程序,(用逗号分隔的应用程序列表)
DIALYZER_ANALYSE_APP=emqx_lwm2m,emqx_authz make dialyzer

社区

FAQ

访问 EMQ X FAQ 以获取常见问题的帮助。

问答

GitHub Discussions EMQ 中文问答社区

参与设计

如果对 EMQ X 有改进建议,可以向EIP 提交 PR 和 ISSUE

插件开发

如果想集成或开发你自己的插件,参考 PLUGIN.md

联系我们

你可通过以下途径与 EMQ 社区及开发者联系:

欢迎你将任何 bug、问题和功能请求提交到 emqx/emqx

MQTT 规范

你可以通过以下链接了解与查阅 MQTT 协议:

MQTT Version 3.1.1

MQTT Version 5.0

MQTT SN

开源许可

详见 LICENSE