RocketMQMessageListener有时间无法监听到数据

其实已经发送成功了,但是有时无法监听到数据造成无法消费者

  1. 消费组多个实例,抢占式消费

场景:

你用的是默认的 集群消费模式(CLUSTERING),如果你有 多个消费者实例(本地启动多个、或者微服务有多个副本),一条消息只会给一个实例消费。

👉 所以你会出现:

A 启动的时候能收到消息

B 启动之后,A 就收不到了(消息被 B 消费了)

✅ 解决方案:

如果你想所有消费者都能收到消息,改为广播模式:

@RocketMQMessageListener(
    topic = "lili_member_topic",
    consumerGroup = "member-consumer-group",
    messageModel = MessageModel.BROADCASTING // 👈 重点
)

简单总结这句话的意思:

RocketMQ 的默认模式是集群消费(CLUSTERING),这个模式下:

同一个消费者组(consumerGroup)里的多个实例,会“平均分摊”消费消息,一条消息只会被其中一个实例处理。

🌰 举个最常见的例子:

你有两个服务实例都在监听 lili_member_topic:

@RocketMQMessageListener(

topic = "lili_member_topic",
consumerGroup = "member-group"

)

你启动了 服务 A ➜ 它能收到消息。

然后你启动了 服务 B ➜ 它也能收到消息。

但:

同一条消息只会发给其中一个服务(A 或 B),不会同时发给两个。

所以你看到 A 有时候收不到,那可能是消息刚好被 B 收走了。

这就是“你以为监听不到,其实被别人消费了”。
✅ 怎么解决?

看你需求是什么:
✅ 如果你想“每个服务实例都收到一份”:

那你就要改为 广播模式(BROADCASTING):

@RocketMQMessageListener(

topic = "lili_member_topic",
consumerGroup = "member-group-A", // 👈 每个实例最好用不同 group(广播模式建议)
messageModel = MessageModel.BROADCASTING

)

🚨 注意:广播模式下,每条消息每个实例都会收到一份,不适合处理订单扣库存这种需要幂等处理的场景,更适合做通知、日志同步、刷新缓存等。
🤔 最后一句话总结你这个情况:

“监听不到” ≠ “没发消息”,而是 消息被同一个 group 下的其他实例消费了。

0

版权声明 ▶ 本网站名称:我的学习笔记
▶ 本文链接:https://ooolo.net/article/614.html
▶ 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行核实删除。
▶ 转载本站文章需要遵守:商业转载请联系站长,非商业转载请注明出处!!!

none
最后修改于:2025年04月19日 20:02

添加新评论

icon_mrgreen.pngicon_neutral.pngicon_twisted.pngicon_arrow.pngicon_eek.pngicon_smile.pngicon_confused.pngicon_cool.pngicon_evil.pngicon_biggrin.pngicon_idea.pngicon_redface.pngicon_razz.pngicon_rolleyes.pngicon_wink.pngicon_cry.pngicon_surprised.pngicon_lol.pngicon_mad.pngicon_sad.pngicon_exclaim.pngicon_question.png