开发者社区 > 云原生 > 消息队列 > 正文

大佬们,我们使用flink rocketmq connector进行线上数据同步,结果在rocke?

问题1:大佬们,我们使用flink rocketmq connector进行线上数据同步,结果在rocketmq的一个broker down机的时候,发生了严重的生成故障,我理解一个broker挂掉应该不至于导致整个系统不可用,谁有比较熟悉一点的人吗? broker宕机时 ● 普通消费只是拉不到消息,不会引起故障,仅打印warn日志 ● flink消费拉取不到消息,就会把异常抛出,导致任务起不来,引起故障

这是我们这边的结论,有对这块了解的吗? 问题2: 但是其中一个挂了,应该是无影响才对,立马切到从节点吧,而不是整个flink任务挂掉,这个 flink rocketmq connector应该很严谨的才对,image.png 我想这设计不至于这么弱吧 org.apache.rocketmq rocketmq-flink 1.0.2-RELEASE

展开
收起
cuicuicuic 2023-07-03 16:26:56 202 0
5 条回答
写回答
取消 提交回答
  • 对于问题1,您的理解是正确的。当一个RocketMQ broker宕机时,普通消费者只是无法拉取到消息,并会打印警告日志,但不会导致系统故障。然而,如果使用Flink消费者无法拉取到消息,会抛出异常,导致任务无法启动,从而引发故障。

    对于问题2,确实在一个broker宕机时,应该没有影响,并且应该立即切换到备用节点。但是,具体实现可能取决于您使用的Flink RocketMQ Connector版本和配置。您提到的版本是1.0.2-RELEASE,但没有提供足够的信息来判断是否有其他配置或自定义逻辑导致了这个问题。建议您检查相关配置和代码逻辑,以确保正确处理broker宕机情况。

    同时,您也可以考虑升级到最新版本的Flink RocketMQ Connector,以获取更好的可靠性和容错性能。

    2023-07-21 21:54:16
    赞同 展开评论 打赏
  • 天下风云出我辈,一入江湖岁月催,皇图霸业谈笑中,不胜人生一场醉。

    问题1: 根据您的描述,您在使用flink rocketmq connector进行线上数据同步时遇到了严重的生成故障。在一个broker down机的时候,发生了整个系统不可用的情况。您理解一个broker挂掉应该不至于导致整个系统不可用,但是在实际使用中遇到了这种情况。您想知道是否有人对这块比较熟悉。 问题2: 根据您的描述,您在使用flink rocketmq connector进行线上数据同步时遇到了一个broker down机的情况。在这种情况下,您想知道flink rocketmq connector是否能够立即切换到从节点,而不是整个flink任务挂掉。 在使用flink rocketmq connector进行线上数据同步时,如果一个broker down机,就会导致整个系统不可用的情况。这是因为flink rocketmq connector使用了一个主从结构,其中主节点负责消息的发送和接收,而从节点负责消息的消费。如果主节点挂掉,就会导致整个系统不可用。 在这种情况下,flink rocketmq connector不能立即切换到从节点,而是需要等待主节点重新启动。只有在主节点重新启动之后,才能重新使用从节点进行消息消费。因此,在使用flink rocketmq connector进行线上数据同步时,应该尽量避免出现主节点挂掉的情况,以免影响整个系统的正常运行。 需要注意的是,如果您希望在主节点挂掉的情况下,也能够正常使用从节点进行消息消费,可以考虑使用flink rocketmq connector的备份机制。通过备份机制,可以将消费者的消费偏移量备份到其他节点上,这样即使主节点挂掉,消费者也能从备份节点上获取消费偏移量,从而正常地消费消息。

    2023-07-07 18:41:44
    赞同 展开评论 打赏
  • 北京阿里云ACE会长

    是的

    1. 一个Broker的宕机不应该导致整个系统不可用,因为在RocketMQ中,一个Broker只是整个集群中的一部分,当一个Broker宕机时,其余的Broker应该可以接管它的工作,并保证整个系统的可用性。

    当RocketMQ的一个Broker宕机时,普通消费者只是拉不到消息,不会引起系统故障,而Flink消费者则会抛出异常,导致任务无法启动,这可能是因为Flink消费者有更高的数据处理要求,需要及时获取消息才能保证任务的正常运行。

    1. 如果RocketMQ的一个Broker宕机,应该及时切换到从节点以保证整个集群的可用性。 但是对于Flink RocketMQ Connector而言,它的设计和性能取决于多个因素,例如RocketMQ版本、Flink版本、Connector版本、网络环境等等。在实际使用中,可能会出现性能瓶颈或者其他问题,从而导致任务挂掉。

    Apache RocketMQ的资料推荐:

    官方文档:Apache RocketMQ官方提供了详细的文档,包括快速入门、架构设计、运维管理等方面,是学习和使用RocketMQ的首要参考。

    《RocketMQ技术内幕》:这是一本由RocketMQ核心开发人员撰写的书籍,详细介绍了RocketMQ的设计、实现原理、性能优化等方面的内容,是深入了解RocketMQ的好书籍。

    GitHub仓库:RocketMQ的源代码托管在GitHub上,您可以在这里查看最新的代码、提交问题和贡献代码。

    官方邮件列表:RocketMQ官方提供了邮件列表,您可以在这里与其他用户和开发者交流经验,解决问题。

    RocketMQ社区:RocketMQ社区是由一群热爱RocketMQ的开发者组成的社区,您可以在这里获取最新的技术资讯、参与社区活动和交流学习经验。

    《Apache RocketMQ实战与性能调优》:这是一本由Apache RocketMQ的核心开发者撰写的书籍,介绍了如何在生产环境中使用RocketMQ以及如何进行性能调优。

    博客和技术文章:许多技术博客和文章也提供了有关RocketMQ的实用信息和教程,例如CSDN、掘金、知乎等等。

    2023-07-03 18:22:21
    赞同 展开评论 打赏
  • 问题1:根据您的描述,当RocketMQ的一个broker宕机时,普通消费者只是无法拉取到消息,只会打印警告日志。但是,Flink消费者无法拉取到消息时会抛出异常,导致任务无法启动,从而引发故障。您的结论是正确的。

    这是因为Flink消费者与RocketMQ的交互方式不同于普通消费者。Flink消费者使用的是pull方式,它会主动拉取消息。当Flink消费者无法拉取到消息时,会抛出异常,导致任务无法启动。这是Flink框架的设计决策,为了保证数据的完整性和一致性,它要求所有的输入数据都必须可用。

    问题2:您提到当一个broker宕机时,整个flink任务都会挂掉,而不是切换到从节点。根据您提供的版本信息,您使用的是RocketMQ Flink Connector 1.0.2-RELEASE。在这个版本中,确实没有提供自动切换到从节点的功能。

    要实现从节点的切换,您可以考虑升级到最新版本的RocketMQ Flink Connector,查看是否有这个功能的更新。另外,您还可以自行编写代码,处理broker宕机时的切换逻辑,以保证任务的高可用性。

    总结:Flink和RocketMQ的交互方式导致了Flink任务在无法拉取到消息时会抛出异常,从而导致任务无法启动。在RocketMQ Flink Connector 1.0.2-RELEASE中,并没有提供自动切换到从节点的功能。您可以考虑升级到最新版本的RocketMQ Flink Connector,或者自行编写代码实现从节点的切换逻辑,以提高任务的可用性。

    2023-07-03 17:14:54
    赞同 展开评论 打赏
  • 回答1:目前应该是启动的时候获取到所有的队列,在run方法中进行遍历,逐个进行消息拉取,所以你可以看看是否是去了挂掉的节点进行消息拉取,你是用的哪个分支啊 ,此回答整理自钉群“群2-Apache RocketMQ 中国开发者钉钉群”

    2023-07-03 16:34:31
    赞同 展开评论 打赏

多个子产品线联合打造金融级高可用消息服务以及对物联网的原生支持,覆盖多行业。

相关产品

  • 云消息队列 MQ
  • 相关电子书

    更多
    RocketMQ Client-GO 介绍 立即下载
    RocketMQ Prometheus Exporter 打造定制化 DevOps 平台 立即下载
    基于 RocketMQ Prometheus Exporter 打造定制化 DevOps 平台 立即下载