版本发布
v4.3.22
发布日期: 2022-11-26
这是 EMQX 开原版 v4.3 系列的最后一个版本。
增强
检查监听器的
tls_versions
配置值是tlsv1
,tlsv1.1
,tlsv1.2
,tlsv1.3
中的一个或多个组合 #9260。删除 Dashboard 监听器失败时日志中的无用信息 #9260.
当 CoAP 网关给设备投递消息并收到设备发来的确认之后,回调
'message.acked'
钩子 #9264。 有了这个改动,CoAP 网关可以配合 EMQX (企业版)的离线消息缓存功能,让 CoAP 设备重新上线之后,从数据库读取其离线状态下错过的消息。支持在规则引擎的 Webhook 动作的 HTTP Headers 里使用
${var}
格式的占位符 #9239。在 emqx 启动时,异步地刷新资源和规则 #9199。 这个改动是为了避免因为一些资源连接建立过慢,而导致启动时间过长。
订阅时,如果 ACL 检查不通过,打印一个警告日志 #9124。 该行为的改变主要是为了跟发布失败时的行为保持一致。
基于 JWT 的 ACL 支持
all
动作,指定同时适用于pub
和sub
两个动作的规则列表 #9044。增强包含敏感数据的日志的安全性 #9189。 如果日志中包含敏感关键词,例如
password
,那么关联的数据回被模糊化处理,替换成******
。增强 ACL 模块中的日志安全性,敏感数据将被模糊化 #9242。
增加
management.bootstrap_apps_file
配置,可以让 EMQX 初始化数据库时,从该文件批量导入一些 APP / Secret #9273。增加了固化认证和 ACL 模块调用顺序的配置 #9283。 这两个新的全局配置名称为
auth_order
和acl_order
。 当有多个认证或 ACL 插件(或模块)开启时,没有该配置的话,模块调用的顺序取决于它们的启动顺序。 例如,如果一个插件(或模块)在系统启动之后单独重启了,那么它就有可能排到其他插件(或模块)的后面去。 有了这个配置之后,用户可以使用用逗号分隔的插件(或模块)的名字(或别名)来固化他们被调用的顺序。 例如,acl_order = jwt,http
,可以用于保证jwt
这个模块总是排在http
的前面, 也就是说,在对客户端进行 ACL 检查时,如果 JWT 不存在(或者没有定义 ACL),那么回退到使用 HTTP。为更多类型的
client.disconnected
事件(计数器触发)提供可配置项 #9267。 此前,client.disconnected
事件及计数器仅会在客户端正常断开连接或客户端被系统管理员踢出时触发, 但不会在旧 session 被新连接废弃时 (clean_session = true) ,或旧 session 被新连接接管时 (clean_session = false) 被触发。 可将broker.client_disconnect_discarded
和broker.client_disconnect_takovered
选项设置为on
来启用此场景下的客户端断连事件。规则引擎资源创建失败后,第一次重试前增加一个延迟 #9313。 在此之前,重试的延迟发生在重试失败之后。
修复
修复若上传的备份文件名中包含非 ASCII 字符,
GET /data/export
HTTP 接口返回 500 错误 #9224。改进规则的 "最大执行速度" 的计数,只保留小数点之后 2 位 #9185。 避免在 dashboard 上展示类似这样的浮点数:
0.30000000000000004
。修复在尝试连接 MongoDB 数据库过程中,如果认证失败会不停打印错误日志的问题 #9184。
修复 emqx-sn 插件在“空闲”状态下收到消息发布请求时可能崩溃的情况 #9024。
限速 “Pause due to rate limit” 的日志级别从原先的
warning
降级到notice
#9134。保留老的
emqx_auth_jwt
模块的接口函数,保障热升级之前添加的回调函数在热升级之后也不会失效 #9144。修正了
/status
API 的响应状态代码 #9210。 在修复之前,它总是返回200
,即使 EMQX 应用程序没有运行。 现在它在这种情况下返回503
。修复规则引擎的消息事件编码失败 #9226。 带消息的规则引擎事件,例如
$events/message_delivered
和$events/message_dropped
, 如果消息事件是共享订阅产生的,在编码(到 JSON 格式)过程中会失败。 影响到的版本:v4.3.21
,v4.4.10
,e4.3.16
和e4.4.10
。使规则引擎 API 在 HTTP 请求路径中支持百分号编码的
rule_id
及resource_id
#9190。 注意在创建规则或资源时,HTTP body 中的id
字段仍为字面值,而不是编码之后的值。 详情请参考 创建规则 和 创建资源。修复调用 'DELETE /alarms/deactivated' 只在单个节点上生效的问题,现在将会删除所有节点上的非活跃警告 #9280。
在进行消息重发布或桥接消息到其他 mqtt broker 时,检查 topic 合法性,确定其不带有主题通配符 #9291。
关闭管理端口(默认为8081)上对 HTTP API
api/v4/emqx_prometheus
的认证,Prometheus 对时序数据抓取不在需要配置认证 #9294。
v4.3.21
发布日期: 2022-10-14
增强
TLS 监听器内存使用量优化 #9005。 新增了配置项
listener.ssl.$NAME.hibernate_after
(默认不开启),该配置生效后,TLS 连接进程在空闲一段时间后会进入休眠。 休眠可以较大程度减少内存占用,但是代价是 CPU 利用率会增加。 测试中使用 '5s' (即 5 秒空闲后休眠)可以减少 50% 的内存使用量。默认 TLS Socket 缓存大小设置为 4KB #9007 这样可以有效的避免某些环境中操作系统提供的默认缓存过大而导致 TLS 连接内存使用量大的问题。
关闭对 HTTP API
api/v4/emqx_prometheus
的认证 #8955 。 Prometheus 对时序数据抓取不在需要配置认证。更严格的 flapping 检测,认证失败等也会进行计数 #9045。
当共享订阅的会话终结时候,把缓存的 QoS1 和 QoS2 的消息向订阅组的其他成员进行转发 #9094。 在这个增强之前,可以通过设置配置项
broker.shared_dispatch_ack_enabled
为true
来防止在共享订阅的会话中缓存消息, 但是这种转发因为需要对每个消息进行应答,会增加额外的系统开销。修复延迟发布可能因为修改系统时间而导致的延迟等问题 #8908。
修复
修复 HTTP 客户端库启用 SSL 后 Socket 可能会进入 passive 状态 #9145。
隐藏 redis 客户端错误日志中的密码参数 #9071 也包含了如下一些改进:
- 修复一些其他可能导致密码泄漏的隐患 eredis#19。
- 修复了 eredis_cluster 中连接池命名冲突的问题 eredis_cluster#22 同时对这个库也进行了密码泄漏隐患对修复。
修复共享订阅消息转发逻辑 #9094。
- QoS2 飞行窗口消息丢弃的日志过度打印问题
- 对于通配符订阅的消息,会话中缓存的消息重发时,因为使用了发布主题(而非通配符主题)来进行重发, 导致无法匹配到共享订阅组内的其他成员。
修复共享订阅
sticky
策略下,客户端取消订阅后仍然可以收到消息的问题 #9119 。 这之前的版本中,仅处理了客户端会话终结,而没有处理取消订阅。修复共享订阅
sticky
策略在某些情况下退化成random
策略的问题 #9122 。 集群环境下,在之前的版本中, 共享订阅组成员的选择在最开始时会随机选取,最终会选中在本节点连接的客户端,并开始粘性转发。 如果所有的订阅客户端都不在本节点,那么粘性策略就会退化成随机。 这个修复后,粘性策略将应用于第一个随机选取的客户端,不论该客户端是不是在本节点。修复规则引擎的备选(fallback)动作的计数重置失败的问题 #9125。
v4.3.20
发布日期: 2022-09-17
增强
- JWT 认证中的
exp
、nbf
和iat
声明支持非整数时间戳
修复
- 修复规则引擎的更新行为,此前会尝试初始化已禁用的规则
- 修复 Dashboard 监听器绑定 IP 地址不生效的问题
- 修复
shared_dispatch_ack_enabled
配置为 true 时共享订阅可能陷入死循环的问题 - 修复规则引擎 SQL 对空值进行主题匹配时崩溃的问题
v4.3.19
发布日期: 2022-08-29
增强
- 改进 LwM2M 报文解析失败时的日志
- 改进规则引擎错误日志,动作执行失败时的日志中将包含规则 ID(
- 改进
loaded_modules
和loaded_plugins
文件不存在时的提醒日志 - Dashboard 新增修改默认密码的引导
修复
- 修复
client.disconnected
在某些情况下不会触发的问题 - 修复内置数据库认证未区分客户端 ID 和用户名的认证数据的分页统计的问题
- 修复 Redis 驱动进程泄漏的问题
- 修复规则引擎 MQTT 桥接至 AWS IOT 连接超时的问题
- 修复监听器未就绪时
GET /listener
请求崩溃的问题 - 修复 v4.3.12 版本后规则引擎 SQL 中任意变量与空值比较总是返回 false 的问题
- 修复错误地将
emqx_modules
应用作为插件管理的问题 - 修复 ExHook 的执行优先级高于规则引擎时,被 ExHook Message Hook 过滤的主题将无法触发规则引擎的问题
- 修复 ExHook 管理进程因 supervisor 关闭超时而被强制杀死的问题
- 修复 ExProto
client.connect
钩子中 Client ID 参数未定义的问题 - 修复客户端被踢除时 ExProto 不会触发断开连接事件的问题
v4.3.18
发布日期: 2022-08-11
重要变更
- 升级了使用的 OTP 版本,以解决 OTP Bug 导致的低概率出现随机进程失去响应的问题,建议仍在使用 4.3 的用户升级到此版本
- 从下一版本起,我们将停止对 macOS 10 的支持,转为提供 macOS 11 的安装包
增强
- 允许配置连接进程在 TLS 握手完成后进行垃圾回收以减少内存占用,这可以使每个 SSL 连接减少大约 35% 的内存消耗,但相应地会增加 CPU 的消耗
- 允许配置 TLS 握手日志的日志等级以便查看详细的握手过程
v4.3.17
发布日期: 2022-07-29
增强
- 支持对规则引擎中的规则进行搜索和分页
- 提供 CLI
./bin/emqx check_conf
以主动检查配置是否正确 - 优化共享订阅性能
修复
- 修复热升级后一旦卸载了老版本 EMQX 将无法再次启动的问题
- 修复多语言协议扩展中对 UDP 客户端的保活检查错误导致客户端不会过期的问题
- 修复多语言协议扩展中客户端信息没有及时更新的问题
- 修复客户端指定 Clean Session 为 false 重连时,飞行窗口中的共享订阅消息会被尝试重新派发给旧会话进程的问题
- 修复
emqx_lua_hook
插件无法阻止消息发布的问题
v4.3.16
发布日期: 2022-06-30
增强
- 规则引擎消息重发布动作中的 QoS 和保留消息标识现在可以使用占位符
- 支持排他订阅,即一个主题只允许存在一个订阅者
- 现在 Dashboard 和管理 API 的 HTTPS 监听器可以使用受密码保护的私钥文件,提供了
key_password
配置项 - 支持在主题重写规则中使用占位符
%u
和%c
- 支持在消息发布的 API 请求中设置 MQTT 5.0 的 Properties,例如消息过期间隔、响应主题等
- 优化规则引擎资源创建时的 UI,例如折叠部分不常用的选项等
- 为 ExHook 底层的 gRPC 连接开放了 KeepAlive、TCP_NODELAY、SO_RCVBUF 和 SO_SNDBUF 共 4 个与 TCP 相关的配置项
修复
- 修复 Linux 系统中内存计算不准确的问题,并改为计算当前系统的内存占用,而不是 EMQX 的内存占用
- 修复 ExHook 在客户端重连时旧的断开连接事件会晚于新的连接事件触发的问题
- 修复主题重写与延迟发布执行顺序不固定的问题,现在固定为优先执行主题重写
- 修复规则引擎无法编码 MQTT 5.0 用户属性的问题
- 修复客户端使用 MQTT v5.0 以下的协议版本接入时
connack.auth_error
计数不准确的问题 - 修复 LwM2M 和 CoAP 网关的 UDP 监听器无法绑定指定网络接口的问题
- 修复在配置文件中移除默认的 Dashboard 用户后 Dashboard 无法启动的问题
- 修复
client.subscribe
钩子无法拒绝订阅的问题 - 如果 ACL 规则中的占位符没有被替换,则客户端的发布或订阅操作将被拒绝
v4.3.15
发布日期: 2022-06-01
增强
- 为规则引擎 SQL 增加更多的时间转换函数
- 为规则引擎 SQL 增加
float2str/2
函数,支持指定浮点输出精度 - 支持将 JWT 用于鉴权,现在 MQTT 客户端可以使用包含发布订阅白名单的特定声明进行授权
- 改进认证相关指标使更易理解,现在
client.authenticate = client.auth.success + client.auth.failure
- 支持 REST API 的监听器绑定到指定的网络接口上
- 支持对使用内置数据库作为数据源的认证鉴权中的用户数据进行多条件查询和模糊查询
- 支持将消息队列长度以及丢弃消息数量作为条件查询客户端
- 支持配置日志时间格式以兼容旧版本中的时间格式
- 当
use_username_as_clientid
配置为true
且客户端连接时未指定username
,现在将拒绝连接并返回0x85
原因码 - App secret 从部分随机改为完全随机
- 现在不兼容版本之间的热升级将被拒绝
- 允许 EMQX 的安装路径中有空格
- 引导脚本将在遇到无效的节点名称时快速失败,并提高错误消息的可读性
修复
- 修复规则引擎 SQL 函数
hexstr_to_bin/1
无法处理半字节的问题 - 修复规则引擎资源删除时告警未被清除的问题
- 修复 Dashboard HTTPS 监听器的
verify
选项未生效的问题 - 修复共享订阅投递 QoS 1 消息过程中对端会话关闭导致消息丢失的问题
- 修复日志跟踪功能跟踪大报文时堆大小增长过快而触发连接进程强制关闭策略的问题
- 修复 MQTT-SN 客户端重传 QoS 2 消息时会被断开连接的问题
- 修复对订阅进行多条件查询时返回结果与查询条件不符的问题
- 修复规则引擎资源连接测试不工作的问题
- 修复多项 Dashboard 显示问题
v4.3.14
发布日期: 2022-04-18
增强
- 规则引擎支持拷贝规则以快速复用
- 规则引擎 SQL 支持 zip、gzip 等压缩和解压缩函数
- 改进规则引擎在解析 Payload 失败时的错误提示
- 优化规则引擎部分资源的连接测试
- 支持为 ExHook 设置执行优先级
- ExHook 回调接口新增
RequestMeta meta
Protobuf 字段用于返回 EMQX 集群名称 - 为共享订阅添加
local
策略,这将优先向消息流入的节点下的共享订阅者发送消息。在某些场景下会提升共享消息调度的效率,尤其是在 MQTT 桥接配置为共享订阅时 - 为 TLS 新增对
RSA-PSK-AES256-GCM-SHA384
、RSA-PSK-AES256-CBC-SHA384
、RSA-PSK-AES128-GCM-SHA256
、RSA-PSK-AES128-CBC-SHA256
四个 PSK 加密套件的支持,从默认配置中移除PSK-3DES-EDE-CBC-SHA
和PSK-RC4-SHA
这两个不安全的加密套件 - 打印 Mnesia
wait_for_table
诊断日志- 打印 Mnesia 内部统计的检查点
- 打印每个表加载统计的检查点,帮助定位表加载时间长的问题
- 严格模式下禁止订阅为空的主题
- 当
loaded_modules
和loaded_plugins
文件不存在时生成默认文件
修复
- 修复 TLS 配置项
server_name_indication
设置为 disable 不生效的问题 - 修复 MongoDB 驱动潜在的进程泄漏问题
- 修复通过 CLI 命令修改的 Dashboard 默认用户的密码会在节点离开集群后重置的问题
- 静默
docker-entrypoint.sh
中的 grep 和 sed 命令的运行错误日志 - 修复 API 路径包含 ISO8859-1 转义字符时,备份文件无法被正确删除和下载
- 修复 Redis 驱动在 DNS 解析失败等情况下会引发崩溃的问题
- 修复规则引擎发送数据到 Web 服务动作中 Headers 字段配置不生效的问题
- 修复 MQTT Bridge 插件仅配置订阅主题但未配置 QoS 时无法启动的问题
- 创建规则时如果已经有使用相同 ID 的规则存在,现在规则引擎将报错而不是替换已有规则
- 修复 HTTP 驱动进程池可能无法删除的问题
v4.3.13
发布日期: 2022-04-01
重要变更
- 对于 Docker 镜像,配置目录
/opt/emqx/etc
已经从 VOLUME 列表中删除,这使用户可以更容易地使用更改后的配置来重建镜像。 - CentOS 7 Erlang 运行系统在 OpenSSL-1.1.1n(之前是 1.0)上重建,在 v4.3.13 之前,客户端使用某些密码套件时,EMQX 将无法成功握手并触发
malformed_handshake_data
异常。 - CentOS 8 Erlang 运行时系统在 RockyLinux 8 上重新构建。
centos8
将继续保留在包名中以保持向后兼容。
增强
- 新增命令行接口
emqx_ctl pem_cache clean
,允许强制清除 x509 证书缓存,以在证书文件更新后立即重新加载。 - 重构 ExProto,以便匿名客户端也可以显示在 Dashboard 上。
- 桥接中的主题配置项现在可以使用
${node}
占位符。 - 严格模式下新增对 MQTT 报文中的 UTF-8 字符串有效性检查。设置为
true
时,无效的 UTF-8 字符串将导致客户端连接断开。 - MQTT-SN 网关支持会话恢复时主动同步注册主题。
- 将规则引擎浮点型数据的写入精度从为小数点后 10 位提升至 17 位。
- EMQX 将在启动时提示如何修改 Dashboard 的初始密码。
修复
- 修复 el8 安装包在 Amazon Linux 2022 上无法启动的问题,错误内容为
errno=13 Permission denied
。 - 修复某些情况下如果连接进程阻塞,客户端无法重连的问题,现在等待超过 15 秒无响应将强制关闭旧的连接进程。
- 修复规则引擎资源不可用时查询资源请求超时的问题。
- 修复热升级运行失败后再次运行出现
{error, eexist}
错误的问题。 - 修复向不存在的主题别名发布消息会导致连接崩溃的问题。
- 修复通过 HTTP API 在另一个节点上查询 lwm2m 客户端列表时的 500 错误。
- 修复主题订阅的 HTTP API 在传入非法的 QoS 参数时崩溃的问题。
- 修复通过多语言协议扩展功能接入的连接进程异常退出时未释放相关资源导致连接计数不更新的问题。
- 修复
server_keepalive
配置项的值会被错误应用于 MQTT v3.1.1 客户端的问题。 - 修复 Stomp 客户端无法触发
$event/client_connection
事件消息的问题。 - 修复 EMQX 启动时系统内存告警误激活的问题。
- 修复向 MQTT-SN 客户端成功注册主题时没有重传此前因未注册主题而投递失败的消息的问题。
- 修复
loaded_plugins
文件中配置了重复的插件时 EMQX 启动输出错误日志的问题。 - 修复 MongoDB 相关功能在配置不正确时输出过量错误日志的问题。
- 增加对 Dashboard User 与 AppID 的格式检查,不允许出现
/
等特殊字符。 - 将踢除客户端时返回的 DISCONNECT 报文中的原因码更正为
0x98
。 - 代理订阅将忽略为空的主题。
v4.3.12
发布日期: 2022-02-11
增强
- 规则引擎支持为客户端消息异常丢失事件配置规则与动作,以增强用户在这一场景的自定义处理能力
- 改进规则引擎 SQL 匹配执行过程中的相关统计指标
- 客户端模糊搜索支持
*
,(
,)
等特殊字符 - 改进 ACL 相关统计指标,解决命中 ACL 缓存导致计数不增加的问题
- Webhook 事件通知中新增
connected_at
字段 - 在因持有锁太久而终止客户端之前记录客户端状态
修复
- 修复 Metrics 接口默认情况下不返回 client.acl.deny 等认证鉴权指标的问题
- 修复订阅查询接口未返回分页数据的问题
- 修复 STOMP 处理 TCP 粘包时解析失败的问题
- 修复客户端过滤查询时会话创建时间选项不可用的问题
- 修复重启后内存告警可能不会触发的问题
- 修复
emqx_auth_mnesia
插件中存在用户数据时导入数据崩溃的问题
v4.3.11
发布日期: 2021-12-17
增强
- 支持配置是否继续投递空的保留消息,以适应仍在使用 MQTT v3.1 协议的用户
修复
- 修复内存占用计算错误的问题
- 修复规则引擎 Webhook Action 的 Path 参数不支持使用 ${Variable} 的问题
- 修复某些情况下停止 MQTT Bridge 插件,会持续打印连接失败日志的问题
v4.3.10
发布日期: 2021-11-11
修复
增强
为 MQTT 客户端引入压力反馈
Github PR: emqx#6065
v4.3.9
发布日期: 2021-11-02
修复
修复集群间调用可能导致客户端进程失去响应的问题
Github PR: emqx#6062
修复 WebHook TLS 不可用的问题
Github PR: emqx#5696
修复 MongoDB 资源不支持域名的问题
Github PR: emqx#6035
修复基于内置数据库的 ACL 的性能问题
Github PR: emqx#5885
修复基于内置数据库的认证错误转码 HTTP 请求参数的问题
Github PR: emqx#5674
修复规则引擎在集群环境下禁用规则后资源无法释放的问题
Github PR: emqx#5731
修复 STOMP 网关若干问题
Github PR: emqx#6040
修复包含 “\” 字符的 Client ID 无法进行模糊搜索的问题
Github PR: emqx#5978
修复可变字节整数可能大于 4 字节的问题
Github PR: emqx#5826
增强
改进客户端踢除机制
Github PR: emqx#6030
为 LwM2M 网关添加新加密套件的支持
Github PR: emqx#5970
支持优先级队列的交错(以避免低优先级队列枯竭)
Github PR: emqx#5666
默认为 HTTP 认证插件关闭超级用户请求
Github PR: emqx#5567
v4.3.8
发布日期: 2021-09-06
修复
修复规则引擎规则导入失败的问题
Github PR: emqx#5512
修复规则引擎 Webhook 动作中 Path 字段无法使用的问题
Github PR: emqx#5468
修复 Force Shutdown 机制在进程挂起时无法生效的问题
Github PR: emqx#5460
修复某些情况下 k8s 部署 EMQX 集群无法正确重启的问题
修复 exproto 跨节点进程间调用的错误
Github PR: emqx#5436
增强
注: 此版本开始 CentoOS 7 要求使用 openssl 1.1.1,openssl 升级安装办法见:FAQ - OpenSSL 版本不正确
v4.3.7
发布日期: 2021-08-09
修复
修复当前 HTTP KeepAlive 行为可能导致某些服务器断开连接的问题
Github PR: emqx#5395
修复命令行接口无法打印某些字符的问题
Github PR: emqx#5411
修复 LwM2M 网关下发整型数字时编码错误的问题
Github PR: emqx#5425
v4.3.6
发布日期: 2021-07-28
增强
v4.3.5
发布日期: 2021-06-28
修复
修复同一客户端建立多个共享订阅时可能在取消订阅后出现消息丢失的问题
Github PR: emqx#5098
v4.3.4
发布日期: 2021-06-23
修复
修复 CoAP 网关无法解析某些 URI 的问题
修复多语言扩展钩子可能启动失败的问题
Github PR: emqx#5004
修复规则引擎删除资源时如果存在依赖该资源的规则会导致 Crash 的问题
Github PR: emqx#4996
修复 HTTP 认证与 Webhook 不支持 Query String 的问题
Github PR: emqx#4981
保证默认配置下节点间报文的转发顺序
Github PR: emqx#4979
v4.3.3
发布日期: 2021-06-05
增强
数据转储支持从 HTTP 请求中获取导入数据
Github PR: emqx#4900
修复
修复没有配置 JWKS 端点导致崩溃的问题
Github PR: emqx#4916
修复 MQTT-SN 在集群环境下的订阅
Github PR: emqx#4915
修复 Webhook 无法使用 TLS 的问题
Github PR: emqx#4908
修复客户端多条件查询时参数错误可能导致崩溃的问题
Github PR: emqx#4916
修复内存占用计算错误的问题
Github PR: emqx#4891
v4.3.2
发布日期: 2021-05-27
修复
修复主题指标监控无法在集群环境使用的问题
Github PR: emqx#4870
修复报文解析时的一些问题
Github PR: emqx#4858
修复 MQTT-SN 睡眠模式与 KeepAlive 机制的冲突问题
Github PR: emqx#4842
修复客户端大量离线时可能出现崩溃的问题
规则引擎刷新资源失败时将资源标记为不可用
Github PR: emqx#4821
v4.3.1
发布日期: 2021-05-14
修复
修复路由压缩之后性能消耗随主题层级数量指数级增长的问题
Github PR: emqx#4800
修复处理大报文的性能问题
修复新增的共享订阅策略不可用的问题
修复了保留消息和延迟发布消息统计指标的错误实现
确保 JSON 日志之间的换行
Github PR: emqx#4778
v4.3.0
发布日期: 2021-05-06
功能与改进
构建
- 支持 Erlang/OTP 23
- 新安装包仅支持 macOS 10.14 及以上版本
- 项目调整为 umbrella 结构
- 支持使用 Elixir 编译插件
性能改进
- 多语言扩展功能底层实现方式由 erlport 改为 gRPC
- 支持路由表压缩,减少内存占用,增强订阅性能,发布性能会略受影响,因此提供了关闭选项
- 优化通配符订阅性能
- 改进大量客户端离线时的处理性能
安全性
- 保护 EMQX Broker 免受跨站点 WebSocket 劫持攻击
- SSL 支持
verify
与server_name_indication
配置项 - SSL 支持证书链最大长度以及私钥文件密码配置项
- JWT 认证支持 JWKS
其他
- 规则引擎新增更新资源逻辑
- 规则引擎 SQL 函数支持 unix 时间戳与 rfc3339 格式时间之间的转换
- 保持对 EMQX Broker 启动后连接失败的资源进行重试
- Websocket 监听器支持从 subprotocols 列表中选择支持的 subprotocol
- WebSocket 连接支持获取真实 IP 与 Port
- 支持 MySQL 8.0 的默认认证方法 caching_sha2_password
- 共享订阅分发策略配置为
round_robin
时随机选择起始点 - 共享订阅支持按源主题的 Hash 分发消息
- 支持 Mnesia 认证信息的导入导出
- 允许使用 Base64 编码的客户端证书或者客户端证书的 MD5 值作为用户名或者 Client ID
- 支持重启监听器
- 仅在正式版本中启用数据遥测功能
- 支持清除所有 ACL 缓存
- 支持 observer_cli
- Prometheus 支持集群指标
- Redis 哨兵模式支持 SSL 连接
- 支持单行日志输出,并支持 rfc3339 时间格式
emqx_auth_clientid
与emqx_auth_usernmae
合并为emqx_auth_mnesia
。请参考 文档 将数据到旧版本导出,并导入到 4.3 中- Docker 默认输出日志到控制台,设置 EMQX_LOG__TO=file 使日志输出到文件
- 支持输出 Json 格式的日志
- 支持 IPv6 自动探测
- 所有发行版都支持环境变量覆盖配置文件(以前仅适用于 Docker)
- 开源版支持 Dashboard 上传证书文件(以前仅适用于企业版)
修复
MQTT 协议
- 修复 MQTTT 心跳报文的处理
- 修复 MQTT 报文接收计数问题
- 限制飞行窗口的最大长度为 65535
- 修复 Server Keep Alive 生效情况下 Dashboard 中 Keep Alive 字段的值未同步的问题
网关
- 修复 CoAP 连接中 ACL 配置不生效的问题
- 修复使用相同 ClientID 的 CoAP 客户端可以同时接入的问题
- 修复 MQTT-SN 睡眠模式不可用的问题
- 修复 MQTT-SN 网关在睡眠模式下会丢弃 DISCONNECT 报文的问题
- 修复 LwM2M 网关将数字编码、解码为无符号整型的问题
资源
- 修复 MySQL 认证 SSL/TLS 连接功能不可用的问题
- 修复 Redis 重连失败问题
其他修复
- 修复 ekka_locker 在极端条件下内存可能无限增长的问题
- 修复 MQTT 桥接功能中
max_inflight_size
配置项不生效的问题 - 修复 MQTT 桥接飞行窗口的问题
- 修复 MQTT 桥接功能中指标统计错误和
retry_interval
字段进行了多次单位转换的问题 - 修复告警持续时间计算错误的问题
- 修复过长的 Client ID 无法追踪的问题
- 修复查询客户端信息可能出现崩溃的问题
- 修复主题重写与 ACL 在发布订阅时执行顺序不一致的问题
- 修复 WebSocket 连接无法使用对端证书作为用户名的问题
- 修复认证数据无法导入的问题
- 修复 Docker 中 EMQX 可能启动失败的问题
- OOM 时快速杀死连接进程
- 修复 Clean Session 为 false 的 MQTT-SN 连接在非正常断开时没有发布遗嘱消息的问题
v4.3-rc.5
发布日期: 2021-04-26
增强
优化通配符订阅性能
支持单行日志输出,并支持 rfc3339 时间格式
Github PR: emqx#4656
支持路由表压缩,减少内存占用,增强订阅性能,发布性能会略受影响,因此提供了关闭选项
Github PR: emqx#4628
规则引擎 SQL 函数支持 unix 时间戳与 rfc3339 格式时间之间的转换
Github PR: emqx#4639
错误修复:
修复 Docker 中 EMQX 可能启动失败的问题
规则引擎资源未初始化成功时将相应规则状态设为不可用
修复在 EMQX 未完全启动时上报遥测数据导致的问题
Github PR: emqx#4627
修复启动 emqx-exhook 插件必须配置 HTTPS 证书的问题
Github PR: emqx#4678
v4.3-rc.4
发布日期: 2021-04-16
增强
Redis 哨兵模式支持 SSL 连接
Github PR: emqx#4553
WebSocket 连接支持获取真实 IP 与 Port
Github PR: emqx#4558
Prometheus 支持集群指标
修复
修复 MQTT 桥接飞行窗口的问题
修复多语言扩展钩子无法处理返回的 false 值的问题
Github PR: emqx#4542
默认启动模块,避免集群后内置模块无法正常工作
Github PR: emqx#4547
修复认证数据无法导入的问题
修复 WebSocket 连接无法使用对端证书作为用户名的问题
Github PR: emqx#4563
修复 MQTT-SN 网关在睡眠模式下会丢弃 DISCONNECT 报文的问题
修复 LwM2M 网关将数字编码、解码为无符号整型的问题
修复部分 HTTP API 不可用的问题
v4.3-rc.3
发布日期: 2021-03-30
修复
限制飞行窗口的最大长度为 65535
Github PR: emqx#4436
修复 Server Keep Alive 生效情况下 Dashboard 中 Keep Alive 字段的值未同步的问题
Github PR: emqx#4444
OOM 时快速杀死连接进程
Github PR: emqx#4451
修复
emqx start
报超时但服务实际已启动的问题Github PR: emqx#4449
修复 MQTT-SN 睡眠模式不可用的问题
Github PR: emqx#4435
v4.3-rc.2
发布日期: 2021-03-26
修复
修复 emqx 和 emqx_ctl 命令在某些情况下不可用的问题
Github PR: emqx#4430
v4.3-rc.1
发布日期: 2021-03-23
增强
支持 observer_cli
Github PR: emqx#4323
支持清除所有 ACL 缓存
Github PR: emqx#4361
SSL 支持
verify
与server_name_indication
配置项Github PR: emqx#4349
修复
修复主题重写与 ACL 执行顺序导致的问题
修复 MQTT 报文接收计数问题
Github PR: emqx#4371
修复心跳报文的处理
修复由于默认的 SSL Ciphers 中包含了 OTP 22 不支持的 Ciphers 导致使用 OTP 22 编译后启动失败的问题
Github PR: emqx#4377
v4.3-beta.1
发布日期: 2021-03-03
增强
减少开启规则引擎插件时的性能损耗
Github PR: emqx#4160
仅在正式版本中启用数据遥测功能
Github PR: emqx#4163
支持重启监听器
禁用规则的同时销毁动作占用的资源
Github PR: emqx#4232
共享订阅分发策略配置为
round_robin
时随机选择起始点Github PR: emqx#4232
允许使用 Base64 编码的客户端证书或者客户端证书的 MD5 值作为用户名或者 Client ID
Github PR: emqx#4194
保持对 EMQX Broker 启动后连接失败的资源进行重试
Github PR: emqx#4125
修复
v4.3-alpha.1
发布日期: 2021-01-29
增强
- 支持 Erlang/OTP 23
- 新安装包仅支持 macOS 10.14 及以上版本
- 规则引擎新增更新资源逻辑
- 增强 Webhook 与 HTTP 认证性能
- 多语言扩展功能底层实现方式由 erlport 改为 gRPC
- 保护 EMQX Broker 免受跨站点 WebSocket 劫持攻击
- 项目调整为 umbrella 结构
- 解决集群环境下节点必须按首次启动顺序启动,否则需要等待前置节点启动的问题
- Websocket 监听器支持从 subprotocols 列表中选择支持的 subprotocol
- 支持 MySQL 8.0 的默认认证方法 caching_sha2_password
- JWT 认证支持 JWKS
- 支持配置证书链最大长度以及私钥文件密码
- 支持 Mnesia 认证信息的导入导出
- 共享订阅支持按源主题的 Hash 分发消息
修复
- 修复 ekka_locker 在极端条件下内存可能无限增长的问题
- 修复 MQTT 桥接功能中
max_inflight_size
配置项不生效的问题 - 修复 CoAP 连接中 ACL 配置不生效的问题
- 修复使用相同 ClientID 的 CoAP 客户端可以同时接入的问题
- 修复告警持续时间计算错误的问题
- 修复 MySQL 认证 SSL/TLS 连接功能不可用的问题
- 修复 MQTT 桥接功能中指标统计错误和
retry_interval
字段进行了多次单位转换的问题 - 修复 Redis 重连失败问题