rocketmq 关于subExpression踩过的坑

问题:本地有两个consumer:

consumer1订阅: TopicTest, Tag1

consumer2订阅: TopicTest, Tag2

注:两个消费者同属于一个消费组

一个生产者:

producer生产:TopicTest, Tag1

consumer1先启动,consumer2后启动,当启动producer时,两个consumer都没有消费到生产的消息;先启动consumer2,后启动consumer1时,consumer1可以消费到一半的消息,consumer2没有消费到消息

结合网上找的一些资料和自己的猜测,对于同一个topic,后启动的会覆盖先启动的 ,所以会出现上面的情况:consumer1先启动时,会被后启动的consumer2覆盖,此时的tag值为Tag2,所以消费不到消息;当consumer1后启动时,覆盖先启动的consumer2,此时的tag值为Tag1,所以可以消费到消息。至于为什么是一半,是因为有两个消费者的缘故,负载均衡。内部细节尚不清楚,应该是有多个map存储topic和consumer,这里先记录下

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值