RocketMQ使用filter失败,报The broker does not support consumer to filter message by SQL92

在实践 RocketMQ 的基于 UserProperty 来对消息进行过滤消费时,启动 consumer 时出现了如下的报错信息:
在这里插入图片描述导致无法正常启动 consumer,通过查看 RocketMQ 中的BrokerConfig 类,发现了问题的原因如下:
在这里插入图片描述在 MQ 的默认配置里,关闭了对 property filter 的支持。
来到 RocketMQ 安装目录的 conf 目录下
在这里插入图片描述
修改 broker 的属性文件broker.conf,添加下面的属性配置即可正常启动。

# 开启对 propertyfilter的支持
enablePropertyFilter = true
filterSupportRetry = true

在这里插入图片描述接下来,重启namesrv与broker服务,再次启动consumer,就一切顺利了!
注意: 如果你是使用 terminal 打开的 namesrv 和 broker,那么你需要关闭当前的 terminal,开启新的 terminal 开启服务(我就遇见了不关闭重启失败的情况)
之所以,出现不关闭 terminal 重启失败的问题,是因为在 RocketMQ 的底层使用的时 Netty 做的通信,一个终端对应的本地服务端口是不会变化的,也就是没办法更新配置信息,可能携带有缓存的问题。


补充说明:使用RocketMQ-4.7.1的版本时,可能出现修改broker.conf配置,按照上述方法重启无效的问题。这是可以采用mqadmin命令来手动更新设置,命令如下:

mqadmin.cmd updateBrokerConfig -blocalhost:10911 -kenablePropertyFilter -vtrue
mqadmin.cmd updateBrokerConfig -blocalhost:10911 -kfilterSupportRetry  -vtrue

接下来,就可以使用 userProperty 结合 SQL92 的标准来定制化消费。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值