RocketMQ多个namesrv使用遇到的坑

1业务背景

最近在做新老系统的mysql数据同步,由于新系统切换为微服务,数据结构设计不同,使用RocketMQ进行异步同步数据。
老系统已经有个老版本的MQ集群,所以在微服务的系统中,需要配置两个MQ集群,一个为新系统服务,另外一个专门为同步数据到老系统服务。

2代码

这里仅仅按照官方文档示例设置了生产组名和namesrv集群地址;

新系统如下使用MQ:

private DefaultMQProducer producer=new DefaultMQProducer("accountProducer");
producer.setNamesrvAddr("新系统集群namesrv地址");
producer.start();
String msgStr = "新系统业务消息内容";
Message msg = new Message(topicName, key, "", msgStr.getBytes());
producer.sendMsg(msg);

老系统如下使用MQ:

private DefaultMQProducer producer=new DefaultMQProducer("asyncToOldSysProducer");
producer.setNamesrvAddr("老系统集群namesrv地址");
producer.start();
String msgStr = "需要同步到老系统的消息内容";
Message msg = new Message(topicName, key, "", msgStr.getBytes());
producer.sendMsg(msg);

3接口测试

通过控制台发现后来每次应该发到老系统MQ的消息,都发到新系统MQ集群里了,奇怪了半天,检查老系统的namesrv地址没有配错啊,随后发现是DefaultMQProducer每次都会去用默认的那个MQClient实例,
应该在新系统使用producer实例时,代码里加上这么一段显式设置,才可以将消息发到老系统MQ集群。

producer.setInstanceName("AsyncToOldSysProducer");

这样如愿达成效果,数据同步到老系统。

4多个消费者实例

多个消费者实例也需要显式设置,具体如下:

DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("SyncUserToNewConsumer");
        //多个注册中心时,需要设置instanceName
        consumer.setInstanceName("SyncUserToNewConsumer");
        consumer.setNamesrvAddr(namesrvaddr);
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值