消息队列批拉超过32不生效!什么情况?

1

说明
由于一些原因,我需要RocketMQ消费的时候,一批拉400条,一批处理400条。设置如下:
消息队列批拉超过32不生效!什么情况?
为了简单验证是否正确,消费如下:
消息队列批拉超过32不生效!什么情况?
直接通过打印msgs.size()观察情况即可。

2

现象
实验的topic里面的消息数量很多很多,但是启动消费端,消费端的日志如下:
消息队列批拉超过32不生效!什么情况?
奇怪啦,明明已经进行了修改
消息队列批拉超过32不生效!什么情况?
为什么还是每次只能消费32条呢?
消息队列批拉超过32不生效!什么情况?

3

调试RocketMQ源码
通过跟踪consumer代码:
消息队列批拉超过32不生效!什么情况?
这里的确已经设置为400了,那么我们需要跟踪到broker服务端进行查看了。
消息队列批拉超过32不生效!什么情况?
broker接受到的也是400,我们只有继续跟踪
消息队列批拉超过32不生效!什么情况?
因为返回为true导致下面的if判断成立,for循环就break了,所有只取了32条数据返回到consumer了:
消息队列批拉超过32不生效!什么情况?
消息队列批拉超过32不生效!什么情况?
如果需要让可以一次拉取400条,需要修改broker这里的数据配置才可(其实关于一条消息大小也是类似的,虽然说最大设置16M,但是也是和这里同理需要设置broker相关的数据配置才可生效)。
修改broker的配置文件,添加:maxTransferCountOnMessageInMemory=400 重启broker即可,效果如下:
消息队列批拉超过32不生效!什么情况?
效果正常,其实如果消息过大,还需要考虑下面几个参数:
消息队列批拉超过32不生效!什么情况?
备注:也可以不用重启broker,通过命令实时修改:
消息队列批拉超过32不生效!什么情况?

4

总结
需要RocketMQ消费的时候,一批拉400条,一批处理400条。设置如下:
消息队列批拉超过32不生效!什么情况?
还是达不到效果的,还需要设置broker相关的参数,本次里面设置broker的maxTransferCountOnMessageInMemory=400即可,其他情况需要考虑如下等参数。
消息队列批拉超过32不生效!什么情况?

本站所有文章均来自互联网,如有侵权,请联系站长删除。极客文库 » 消息队列批拉超过32不生效!什么情况?
分享到:
赞(0)

评论抢沙发

评论前必须登录!