白皮书
车云灵活数采方案:释放数据价值,加速智能创新 →

EMQX v4.3 正式发布:性能大幅提升,更好用的多语言扩展

Guowei Li
2021-5-14
EMQX v4.3 正式发布:性能大幅提升,更好用的多语言扩展

连接海量物联网设备的 MQTT 消息服务器 - EMQX 是基于高并发的 Erlang/OTP 语言平台开发,支持百万级连接和分布式集群架构。EMQX 已经在全球物联网市场广泛应用,无论是产品原型设计、物联网创业公司、还是大规模的商业部署,都支持免费使用。

产品介绍:https://www.emqx.com/zh/products/emqx

下载地址:https://www.emqx.com/zh/try?product=broker

概览

EMQX v4.3.0 版本修复了一些已知问题并新增了诸多特性,在通配符订阅性能、路由表内存占用、规则引擎性能以及大量客户端离线处理性能方面做了较大改进,同时将 多语言 扩展底层通信方式由 erlport 更换为更为灵活的 gRPC 通信。

该版本是 4.x 最后一个次要版本,旨在于为用户提供一个功能丰富、性能稳定的 MQTT 服务器,推荐所有 4.x 用户升级到此版本,此后 4.x 版本将进入维护状态,EMQX Team 将进入到后续 5.0 版本开发工作中。

访问 EMQX GitHub 仓库,点击右上角的 Watch 即可关注 EMQX 5.0 最新动态。

性能测试图

特性概览:observer_cli 查看 Erlang VM 运行状况

升级到 4.3 版本

查看升级指南:https://docs.emqx.com/zh/emqx/v4.3/changes/upgrade-4.3.html#%E5%8D%87%E7%BA%A7%E5%88%B0-4-3-%E7%89%88%E6%9C%AC

详细更新日志:https://docs.emqx.com/zh/emqx/v4.3/changes/changes-4.3.html

性能改进

多语言扩展功能底层实现方式由 erlport 改为 gRPC

多语言扩展允许用户使用其它编程语言如 Python、 Java 等直接向 EMQX 挂载钩子进行业务处理,接收并处理监听器字节数据报文实现自定义协议的解析。

多语言扩展能以用户熟悉的编程语言处理客户端连接生命周期,快速集成到物联网应用中;接入任意的私有协议,享受由 EMQX 带来的诸多性能和功能优势。

此前 EMQX 多语言扩展基于 erlport 进行跨语言通信,考虑到语言支持层面不广、性能水平不足且会与 EMQX 自身功能产生资源竞争问题。在此版本中我们将底层方式更换为 gRPC,能够更好的实现跨语言和跨平台工作,提供更高的性能和清晰的管理能力,有效改善用户开发和维护难度。

提升规则引擎的性能

此前我们为规则引擎添加了所有可用的钩子,即使没有创建规则 EMQX 触发任何事件时都会尝试去匹配规则,导致不必要的开销。

此版本中我们进行了改进,仅为已创建的规则添加必要的钩子,有效降提升了规则引擎性能。

支持路由表压缩,减少内存占用

支持路由表压缩,减少内存占用并增强订阅性能,但发布性能会略受影响,因此提供了关闭选项。

优化通配符订阅性能

优化 EMQX 集群条件下通配符订阅性能,比之前版本提升了 10 倍以上。

提升大量客户端同时离线时的处理性能

此前下线消息和新上线消息会在 Broker 进程堆积,我们修复该问题实现了性能提升。

新增特性

规则引擎

  • 规则引擎新增更新资源逻辑,可以在不删除规则的情况下更换动作使用的资源
  • 规则引擎 SQL 函数支持 unix 时间戳与 rfc3339 格式时间之间的转换
  • 保持对 EMQX Broker 启动后连接失败的资源进行重试,避免资源短暂宕机恢复之后规则无法恢复使用

运维管理

  • 支持 observer_cli,在 console 启动模式下输入 observer_cli:start(). 可查看 Erlang VM 实时运行详细状况
  • Prometheus 支持集群指标
  • 支持单行日志输出,并支持 rfc3339 时间格式
  • 支持 IPv6 自动探测
  • 所有发行版都支持环境变量覆盖配置文件(以前仅适用于 Docker)
  • 开源版支持 Dashboard 上传证书文件(以前仅适用于企业版)

MQTT 增强

  • 共享订阅分发策略配置为 round_robin 时随机选择起始点
  • 共享订阅支持按源主题的 Hash 分发消息,设备与共享订阅之间可以有固定的分发通道

其他功能

  • WebSocket 连接支持获取真实 IP 与 Port
  • Websocket 监听器支持从 subprotocols 列表中选择支持的 subprotocol
  • 支持 MySQL 8.0 的默认认证方法 caching_sha2_password
  • 支持 Mnesia 认证信息的导入导出
  • 允许使用 Base64 编码的客户端证书或者客户端证书的 MD5 值作为用户名或者 Client ID
  • 支持重启监听器,某些在监听器设置无需重启 EMQX 即可更新
  • 仅在正式版本中启用数据遥测功能
  • 支持清除所有 ACL 缓存
  • Redis 哨兵模式支持 SSL 连接
  • emqx_auth_clientid 与 emqx_auth_usernmae 合并为 emqx_auth_mnesia。请参考 文档 将数据到旧版本导出,并导入到 4.3 中
  • Docker 默认输出日志到控制台,设置 EMQX_LOG__TO=file 使日志输出到文件
  • 支持输出 JSON 格式的日志,某些日志分析系统如 ELK 可以更好的进行配置使用

安全性提升

  • 保护 EMQX Broker 免受跨站点 WebSocket 劫持攻击
  • SSL 支持 verify 与 server_name_indication 配置项
  • SSL 支持证书链最大长度以及私钥文件密码配置项
  • JWT 认证支持 JWKS

开发构建

  • 支持 Erlang/OTP 23

    升级到 Erlang/OTP 23 版本,为提高特性更新和错误修复速度,EMQX fork 并维护了 Erlang/OTP 项目,默认使用 http://github.com/emqx/otp 进行构建。

  • 新安装包仅支持 macOS 10.14 及以上版本

  • 项目调整为 umbrella 结构

    项目结构调整之后降低了依赖管理的复杂度,同依赖之间互相关联的修改原子性得到保障;同时 review 和测试复杂度降低,对社区开发者更加友好。

  • 支持使用 Elixir 编译插件

错误修复

MQTT 协议

  • 修复 MQTT 心跳报文的处理
  • 修复 MQTT 报文接收计数问题
  • 限制飞行窗口的最大长度为 65535
  • 修复 Server Keep Alive 生效情况下 Dashboard 中 Keep Alive 字段的值未同步的问题

网关

  • 修复 CoAP 连接中 ACL 配置不生效的问题
  • 修复使用相同 ClientID 的 CoAP 客户端可以同时接入的问题
  • 修复 MQTT-SN 睡眠模式不可用的问题
  • 修复 MQTT-SN 网关在睡眠模式下会丢弃 DISCONNECT 报文的问题
  • 修复 LwM2M 网关将数字编码、解码为无符号整型的问题
  • 修复 Clean Session 为 false 的 MQTT-SN 连接在非正常断开时没有发布遗嘱消息的问题

资源

  • 修复 MySQL 认证 SSL/TLS 连接功能不可用的问题
  • 修复 Redis 重连失败问题

其他修复

  • 修复 ekka_locker 在极端条件下内存可能无限增长的问题
  • 修复 MQTT 桥接功能中 max_inflight_size 配置项不生效的问题
  • 修复 MQTT 桥接飞行窗口的问题
  • 修复 MQTT 桥接功能中指标统计错误和 retry_interval 字段进行了多次单位转换的问题
  • 修复告警持续时间计算错误的问题
  • 修复过长的 Client ID 无法追踪的问题
  • 修复查询客户端信息可能出现崩溃的问题
  • 修复主题重写与 ACL 在发布订阅时执行顺序不一致的问题
  • 修复 WebSocket 连接无法使用对端证书作为用户名的问题
  • 修复认证数据无法导入的问题
  • 修复 Docker 中 EMQX 可能启动失败的问题
  • 修复 OOM 时快速杀死连接进程
免费试用 EMQX 企业版
开始试用 →

推荐阅读