RocketMQ不消费问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了RocketMQ不消费问题相关的知识,希望对你有一定的参考价值。

参考技术A 最近在一项目中使用RocketMQ,开始配置好服务都正常使用。突然有一天项目启动MQ不消费,最开始以为是MQ出问题并把服务重启问题还是没有解决,后面经过两小时的问题排查发现配置中心的配置被人修改,把name-server后面的多个server地址使用逗号分割,如下图:

正确配置如下:

nacos配置中心配置如下:

RocketMQ相关的版本如下:

RocketMQ消费批拉超过32不生效

由于一些原因,我需要RocketMQ消费的时候,一批拉400条,一批处理400条。设置如下:

技术图片

为了简单验证是否正确,消费如下:

技术图片

直接通过打印msgs.size()观察情况即可。

现象

实验的topic里面的消息数量很多很多,但是启动消费端,消费端的日志如下:

技术图片

奇怪啦,明明已经进行了修改

技术图片

为什么还是每次只能消费32条呢?

调试RocketMQ源码

通过跟踪consumer代码:

技术图片

这里的确已经设置为400了,那么我们需要跟踪到broker服务端进行查看了。

技术图片

broker接受到的也是400,我们只有继续跟踪

技术图片

因为返回为true导致下面的if判断成立,for循环就break了,所有只取了32条数据返回到consumer了:

技术图片

技术图片

如果需要让可以一次拉取400条,需要修改broker这里的数据配置才可(其实关于一条消息大小也是类似的,虽然说最大设置16M,但是也是和这里同理需要设置broker相关的数据配置才可生效)。

修改broker的配置文件,添加:maxTransferCountOnMessageInMemory=400 重启broker即可,效果如下:

技术图片

效果正常,其实如果消息过大,还需要考虑下面几个参数:

技术图片

备注:也可以不用重启broker,通过命令实时修改:

sh mqadmin updateBrokerConfig -c 集群名称 -n namesrv  -k maxTransferCountOnMessageInMemory -v 400

总结

需要RocketMQ消费的时候,一批拉400条,一批处理400条。设置如下:

技术图片

还是达不到效果的,还需要设置broker相关的参数,本次里面设置broker的maxTransferCountOnMessageInMemory=400即可,其他情况需要考虑如下等参数。

技术图片

 

本文转载自http://www.jiangxinlingdu.com/rocketmq/2018/12/05/pullbatchsize.html

以上是关于RocketMQ不消费问题的主要内容,如果未能解决你的问题,请参考以下文章

程序重启RocketMQ消息重复消费

RocketMQ 的 CONSUME_FROM_LAST不生效问题

RocketMq小笔记

rocketmq之顺序消费

RocketMQ消费批拉超过32不生效

RocketMQ的两种消费模型