RocketMQ生产者发送消息失败是如何规避重试时发送给同一个broker?
在没有开启Broker故障延迟机制的的情况下, Producer发送消息的时候有失败重试机制。第一次发送消息的时候 会随机选择一个MessageQueue,MessageQueue中存在brokerName属性,如果发送失败了,则下一次发送消息的时候选择MessageQueue的brokerName不等于第一次发送消息时的brokerName属性。 这样就能规避 第二次发送消息时 仍然发送给第一次发送失败的broker节点。
问题: 为什么书中提到 “如果上一次根据路由算法选择的是若机的 Broker
的第一个队列 ,那么随后的下 次选择的是若机 Broker 的第二个队列,” 怎么可能会选择到宕机broker的第二个队列? 宕机broker不是会根据brokerName被排除在外了吗
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
个人理解,如有不正确的地方请指出
我更加赞同是书中书写有问题。
在一次消息发送的过程中,确实会避免拿到宕机的
broker
,这点在org.apache.rocketmq.client.impl.producer.TopicPublishInfo.selectOneMessageQueue(final String lastBrokerName)
的函数中已经写的非常清楚了。在这个函数中您也可以得到
rocketmq
在同一个topic
消息发送的负载均衡逻辑。另外您理解的 第一次发送消息的时候会随机选择一个
MessageQueue
,这个也是不正确的,它是会按照顺序依次选择队列。