当前位置: 首页 > news >正文

发送失败的RocktMQ消息,你遇到过吗?

背景

需要通过flink同时向测试和线上的RocketMQ中写入数据

现象

在程序中分别创建了两个MqProducer,设置了不同的nameServerAddr,分别调用不同的producer向不同环境发消息,返回发送成功,但是在线上MQ中却查不到数据,测试环境是有的。
代码如下:

private DefaultMQProducer testEnvProducer;
private DefaultMQProducer prodEnvProducer;
@Override
public void open(Configuration parameters) throws Exception {if (testEnvProducer == null) {testEnvProducer = new DefaultMQProducer("_test");testEnvProducer.setNamesrvAddr(SINK_ADDRESS);testEnvProducer.start();}if (prodEnvProducer == null) {prodEnvProducer = new DefaultMQProducer("_prod");prodEnvProducer.setNamesrvAddr(SOURCE_ADDRESS);prodEnvProducer.start();}
}

在这里插入图片描述

解决过程及方案

由于不了解flink的运行机制,尝试将发送MQ的逻辑拆分为两个sink,无济于事,在中间遇到了创建DefaultMQProducer时设置的是同一个group,理论上是不同的环境不会有问题,prodProducer在start时却报该group的实例已经创建,当时就有点怀疑是不是两个producer是同一个。后又通过在消息体中增加profile明确区分开线上和测试的数据,发现应该发送到线上的数据却发送到了测试环境,此时断定是两个producer为同一个实例。
查看RocketMQ Client源码发现了factory这个参数
image.png
在这里插入图片描述

那问题大概率就是这个工厂导致的,工厂内做了缓存,让我们来看一看
image.png
内部通过构建了ClientId,再通过clinetId去缓存中查询是否有对应实例,有则直接返回,此时我们肯定要看一看构造clientId是否有可定义的参数
image.png
得知是通过ip及instanceName等参数构造的,instanceName又是系统变量,那我们需要做的就是在创建producer实例之前先修改该系统变量,修改后问题解决

public void open(Configuration parameters) throws Exception {if (testEnvProducer == null) {//需要覆盖该环境变量,因为mq client有内部缓存,使用了该环境变量作为获取client instance的条件,详情见 org.apache.rocketmq.client.ClientConfig#buildMQClientIdSystem.setProperty("rocketmq.client.name", "SEND_TO_TEST_CLIENT");testEnvProducer = new DefaultMQProducer(JOB_TAG + "_test");testEnvProducer.setNamesrvAddr(SINK_ADDRESS);testEnvProducer.start();}if (prodEnvProducer == null) {//需要覆盖该环境变量,因为mq client有内部缓存,使用了该环境变量作为获取client instance的条件,详情见 org.apache.rocketmq.client.ClientConfig#buildMQClientIdSystem.setProperty("rocketmq.client.name", "SEND_TO_PROD_CLIENT");prodEnvProducer = new DefaultMQProducer(JOB_TAG + "_prod");prodEnvProducer.setNamesrvAddr(SOURCE_ADDRESS);prodEnvProducer.start();}
}

大家在实际开发中如果有这种场景的话也要注意哦!
在这里插入图片描述

http://www.lryc.cn/news/227211.html

相关文章:

  • Unity中全局光照GI的总结
  • 毫米波雷达技术在自动驾驶中的关键作用:安全、精准、无可替代
  • Jetson平台180度鱼眼相机畸变校正调试记录
  • axios请求的问题
  • 【pandas刷题系列】Leetcode Problem: [595. 大的国家]
  • 【打卡】牛客网:BM46 最小的K个数
  • Android各类View触摸监听器失效
  • 未整理的知识链接
  • 【2011年数据结构真题】
  • 【科研绘图】MacOS上的LaTeX公式插入工具——LaTeXiT
  • 仓库自动化中的RFID技术的应用浅谈
  • 容器网络-Underlay和Overlay
  • 基于FPGA的PCIe-Aurora 8/10音频数据协议转换系统设计阅读笔记
  • stm32控制舵机sg90
  • state 和 props 有什么区别?
  • Unity 获取桌面路径的方法
  • 基于SSM的考研图书电子商务平台的设计与实现
  • 信息系统“好用”的标准探讨
  • vue elementui 实现从excel从复制多行多列后粘贴到前端界面el-table
  • C++学习 --类和对象之友元
  • Flutter笔记:使用Flutter构建响应式PC客户端/Web页面-案例
  • 聊聊LogbackMDCAdapter
  • spring命名空间注入和XML自动装配、引入外部配置文件
  • 【2024年11月份--2024精灵云校招C++笔试题】
  • Visual Studio 2019下编译OpenCV 4.7 与OpenCV 4.7 contrib
  • 【Linux网络】系统调优之聚合链路bonding,可以实现高可用和负载均衡
  • k8s持久化存储PV、PVC
  • CocosCreator3.8原生引擎源码研究
  • 高二英语上
  • JavaWeb Day10 案例 准备工作