ROCKETMQ 主从切换机制

在RocketMQ的一主一从集群配置中,当Master宕机,Consumer如何自动切换到Slave进行消息消费。官方文档指出,Master故障时,Slave仍可处理消费请求。Master恢复后,Consumer能继续消费Master的消息。本文将探讨Consumer如何判断并执行从Master到Slave的切换,以及该过程是否涉及负载均衡服务的重新分配。

       之前看rocketmq,然后在想一个问题,就是一主一从的集群结构中,如果master宕机了,consumer这边是怎么选择的,按照官方说明中,master挂了,但是slave中的消息仍然可以被consume消费到,然后master恢复后,master的消息又可以被消费到。

       那么问题来了,consumer是怎么从master上面切换到slave上继续消费消息呢?首先明确一点,master宕机,就意味着这个broker不再写入,但是因为slave还在,所以还可以继续读。所以我们看一下consumer是怎么选择的?其实还有个疑问,就是master宕机后,会体现到负载均衡服务的重新分配吗?

       先说第一个问题,跟代码进去:

       PullConsumer:

 

PullResult pullResult =
                        consumer.pullBlockIfNotFound(mq, null, getMessageQueueOffset(mq), 32);

一路next 到  
pullAPIWrapper.pullKernelImpl
 
然后发现,消费者消费从哪个服务器上面拉信息是通过这样确定的:
 
public FindBrokerResult findBrokerAddressInSubscribe(
    final String brokerName,
    final long brokerId,
    final boolean onlyThisBroker
) {
    String brokerAddr = null;
    boolean 
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值