RocketMQ 平滑升级到主从切换(实战篇)

本文主要介绍如何将 RocketMQ 集群从原先的主从同步升级到主从切换。

本文首先介绍与 DLedger 多副本即 RocketMQ 主从切换相关的核心配置属性,然后尝试搭建一个主从同步集群,最后将原先的 RocketMQ 集群平滑升级到 DLedger 集群的示例,并简单测试一下主从切换功能。

1、RocketMQ 主从切换核心配置参数详解


其主要的配置参数如下所示:

  • enableDLegerCommitLog

  • dLegerGroup

  • dLegerPeers

  • dLegerSelfId

  • storePathRootDir

2、搭建主从同步环境


首先先搭建一个传统意义上的主从同步架构,往集群中灌一定量的数据,然后升级到 DLedger 集群。

在 Linux 服务器上搭建一个 rocketmq 主从同步集群我想不是一件很难的事情,故本文就不会详细介绍按照过程,只贴出相关配置。

实验环境的部署结构采取 一主一次,其部署图如下:

640?wx_fmt=png

220 上的 broker 配置文件如下:

 1brokerClusterName = DefaultCluster
 2brokerName = broker-a
 3brokerId = 0
 4deleteWhen = 04
 5fileReservedTime = 48
 6brokerRole = ASYNC_MASTER
 7flushDiskType = ASYNC_FLUSH
 8brokerIP1=192.168.0.220
 9brokerIP2=192.168.0.220
10namesrvAddr=192.168.0.221:9876;192.168.0.220:9876
11storePathRootDir=/opt/application/rocketmq-all-4.5.2-bin-release/store
12storePathCommitLog=/opt/application/rocketmq-all-4.5.2-bin-release/store/commitlog
13autoCreateTopicEnable=false
14autoCreateSubscriptionGroup=false

221 上 broker 的配置文件如下:

 1brokerClusterName = DefaultCluster
 2brokerName = broker-a
 3brokerId = 1
 4deleteWhen = 04
 5fileReservedTime = 48
 6brokerRole = SLAVE
 7flushDiskType = ASYNC_FLUSH
 8brokerIP1=192.168.0.221
 9brokerIP2=192.168.0.221
10namesrvAddr=192.168.0.221:9876;192.168.0.220:9876
11storePathRootDir=/opt/application/rocketmq-all-4.5.2-bin-release/store
12storePathCommitLog=/opt/application/rocketmq-all-4.5.2-bin-release/store/commitlog
13autoCreateTopicEnable=false
14autoCreateSubscriptionGroup=false

相关的启动命令如下:

1nohup bin/mqnamesrv  /dev/null  2>&1 &
2nohup bin/mqbroker -c conf/broker.conf  /dev/null  2>&1 &

安装后的集群信息如图所示:

640?wx_fmt=png

3、主从同步集群升级到DLedger


3.1 部署架构

DLedger 集群至少需要3台机器,故搭建 DLedger 还需要再引入一台机器,其部署结构图如下:

640?wx_fmt=png


 1public class Producer {
 2    public static void main(String[] args) throws MQClientException, InterruptedException {
 3        DefaultMQProducer producer = new DefaultMQProducer("producer_dw_test");
 4        producer.setNamesrvAddr("192.168.0.220:9876;192.168.0.221:9876");
 5        producer.start();
 6        for(int i =600000; i < 600100; i ++) {
 7            try {
 8                Message msg = new Message("topic_dw_test_by_order_01",null , "m" + i,("Hello RocketMQ" + i ).getBytes(RemotingHelper.DEFAULT_CHARSET));
 9                SendResult sendResult = producer.send(msg);
10               //System.out.printf("%s%n", sendResult);
11            } catch (Exception e) {
12                e.printStackTrace();
13                Thread.sleep(1000);
14            }
15        }
16        producer.shutdown();
17        System.out.println("end");
18    }
19}

消息的查询结果示例如下:

640?wx_fmt=png
3.2 升级步骤

Step1:将 192.168.0.220 的 rocketmq 拷贝到 192.168.0.222,可以使用如下命令进行操作。在 192.168.0.220 上敲如下命令:

1 scp -r rocketmq-all-4.5.2-bin-release/ root@192.168.0.222:/opt/application/rocketmq-all-4.5.2-bin-release

温馨提示:示例中由于版本是一样,实际过程中,版本需要升级,故需先下载最新的版本,然后将老集群中的 store 目录完整的拷贝到新集群的 store 目录。

Step2:依次在三台服务器的 broker.conf 配置文件中添加与 dledger 相关的配置属性。

192.168.0.220 broker配置文件如下:

 1brokerClusterName = DefaultCluster
 2brokerId = 0
 3deleteWhen = 04
 4fileReservedTime = 48
 5brokerRole = ASYNC_MASTER
 6flushDiskType = ASYNC_FLUSH
 7brokerIP1=192.168.0.220
 8brokerIP2=192.168.0.220
 9namesrvAddr=192.168.0.221:9876;192.168.0.220:9876
10storePathRootDir=/opt/application/rocketmq-all-4.5.2-bin-release/store
11storePathCommitLog=/opt/application/rocketmq-all-4.5.2-bin-release/store/commitlog
12autoCreateTopicEnable=false
13autoCreateSubscriptionGroup=false
14# 与 dledger 相关的属性
15enableDLegerCommitLog=true
16storePathRootDir=/opt/application/rocketmq-all-4.5.2-bin-release/store/dledger_store
17dLegerGroup=broker-a
18dLegerPeers=n0-192.168.0.220:40911;n1-192.168.0.221:40911;n2-192.168.0.222:40911
19dLegerSelfId=n0

192.168.0.221 broker配置文件如下:

 1brokerClusterName = DefaultCluster
 2brokerName = broker-a
 3brokerId = 1
 4deleteWhen = 04
 5fileReservedTime = 48
 6brokerRole = SLAVE
 7flushDiskType = ASYNC_FLUSH
 8brokerIP1=192.168.0.221
 9brokerIP2=192.168.0.221
10namesrvAddr=192.168.0.221:9876;192.168.0.220:9876
11storePathRootDir=/opt/application/rocketmq-all-4.5.2-bin-release/store
12storePathCommitLog=/opt/application/rocketmq-all-4.5.2-bin-release/store/commitlog
13autoCreateTopicEnable=false
14autoCreateSubscriptionGroup=false
15# 与dledger 相关的配置属性
16enableDLegerCommitLog=true
17storePathRootDir=/opt/application/rocketmq-all-4.5.2-bin-release/store/dledger_store
18dLegerGroup=broker-a
19dLegerPeers=n0-192.168.0.220:40911;n1-192.168.0.221:40911;n2-192.168.0.222:40911
20dLegerSelfId=n1

192.168.0.222 broker配置文件如下:

 1brokerClusterName = DefaultCluster
 2brokerName = broker-a
 3brokerId = 0
 4deleteWhen = 04
 5fileReservedTime = 48
 6brokerRole = ASYNC_MASTER
 7flushDiskType = ASYNC_FLUSH
 8brokerIP1=192.168.0.222
 9brokerIP2=192.168.0.222
10namesrvAddr=192.168.0.221:9876;192.168.0.220:9876
11storePathRootDir=/opt/application/rocketmq-all-4.5.2-bin-release/store
12storePathCommitLog=/opt/application/rocketmq-all-4.5.2-bin-release/store/commitlog
13autoCreateTopicEnable=false
14autoCreateSubscriptionGroup=false
15# 与 dledger 相关的配置
16enableDLegerCommitLog=true
17storePathRootDir=/opt/application/rocketmq-all-4.5.2-bin-release/store/dledger_store
18dLegerGroup=broker-a
19dLegerPeers=n0-192.168.0.220:40911;n1-192.168.0.221:40911;n2-192.168.0.222:40911
20dLegerSelfId=n2

温馨提示:legerSelfId 分别为 n0、n1、n2。在真实的生产环境中,broker配置文件中的 storePathRootDir、storePathCommitLog 尽量使用单独的根目录,这样判断其磁盘使用率时才不会相互影响。

Step3:将 store/config 下的 所有文件拷贝到 dledger store 的 congfig 目录下。

1cd /opt/application/rocketmq-all-4.5.2-bin-release/store/
2cp config/* dledger_store/config/
3

温馨提示:该步骤按照各自按照时配置的目录进行复制即可。

Step4:依次启动三台 broker。

1nohup bin/mqbroker -c conf/broker.conf  /dev/null  2>&1 &

如果启动成功,则在 rocketmq-console 中看到的集群信息如下:

640?wx_fmt=png
3.3 验证消息发送与消息查找

首先我们先验证升级之前的消息是否能查询到,那我们还是查找key 为 m600000 的消息,查找结果如图所示:

640?wx_fmt=png

然后我们来测试一下消息发送。测试代码如下:

 1public class Producer {
 2    public static void main(String[] args) throws MQClientException, InterruptedException {
 3        DefaultMQProducer producer = new DefaultMQProducer("producer_dw_test");
 4        producer.setNamesrvAddr("192.168.0.220:9876;192.168.0.221:9876");
 5        producer.start();
 6        for(int i =600200; i < 600300; i ++) {
 7            try {
 8                Message msg = new Message("topic_dw_test_by_order_01",null , "m" + i,("Hello RocketMQ" + i ).getBytes(RemotingHelper.DEFAULT_CHARSET));
 9                SendResult sendResult = producer.send(msg);
10                System.out.printf("%s%n", sendResult);
11            } catch (Exception e) {
12                e.printStackTrace();
13                Thread.sleep(1000);
14            }
15        }
16        producer.shutdown();
17        System.out.println("end");
18    }
19}

执行结果如下:

640?wx_fmt=png


640?wx_fmt=png

在消息发送的过程中,去关闭主节点,其截图如下:

640?wx_fmt=png
640?wx_fmt=png
640?wx_fmt=png

640?wx_fmt=png

等待该复制组重新完成主服务器选举后,即可继续处理消息发送。

温馨提示:由于本示例是一主一从,故在选举期间,消息不可用,但在真实的生产环境上,其部署架构是多主主从,即一个复制组在 leader 选举期间,其他复制组可以接替该复制组完成消息的发送,实现消息服务的高可用。

与 DLedger 相关的日志,默认存储在 broker_default.log 文件中。

本文就介绍到这里了,如果觉得文章对您有帮助的话,还希望帮忙点个【在看】,谢谢。


推荐阅读

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值