问题:本地有两个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,这里先记录下