热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

具有高可用性的kafkaMulti-Datacenter

如何解决《具有高可用性的kafkaMulti-Datacenter》经验,为你挑选了1个好方法。

我在不同的DC上设置了2个kafka v0.10.1.0集群,并计划使用mirror-maker来保持一个作为源,另一个作为目标,我不确定如何在我的源代码时确保高可用性/主群集关闭(源kafka群集关闭的完整DC)我是否需要让我的应用程序切换到目标kafka生成消息以及源kafka返回时会发生什么?如何将其与可能丢失的消息同步恢复?

谢谢



1> Sönke Liebau..:

从阅读你的问题我不认为,MirrorMaker将是一个适合你的需求的工具,我担心.

基本上,MirrorMaker只是一个消费者和生产者联系在一起,将消息从一个集群复制到另一个集群.它不是一个将两个Kafka集群绑定在一个主动 - 主动配置中的工具,这听起来很像你正在寻找的东西.

但要按顺序回答您的问题:

我是否需要切换应用程序以向目标kafka发送消息?

是的,目前没有故障转移功能,您需要在生产者中实现逻辑,以便在x个失败的消息之后尝试目标集群,或者在y分钟或类似的情况下没有发送消息.

当源kafka回来时会发生什么?

几乎没有你自己没有实现的东西:) MirrorMaker将开始再次将数据从源集群复制到目标集群,但由于您的生产者现在切换到目标集群,因此源集群没有获取任何数据,因此他们会闲着 除非您定期检查源是否重新联机并让它们切换回来,否则您的生产者将继续生产到目标群集中.

如何将其与可能丢失的消息同步?

当您的源群集重新联机并假设上面提到的所有内容都已发生时,您有效地切换了您的群集,具体取决于您是否希望将源作为主群集写入或者很乐意在发生这种情况时反转角色,您有两个我可以提出的选项:

反转mirrormaker的方向并手动设置使用者组的偏移量,以便它在源群集死亡的位置拾取

停止生成新数据一段时间,将丢失的数据恢复到源群集,切换回生产者并重新启动所有内容.

这两个选项都要求你弄清楚,手动群集上手动丢失了哪些数据,我认为没有办法解决这个问题.


最重要的是,这对于MirrorMaker来说并不是一件容易的事情,如果资源消失,你是否真的想要将生产者转移到目标集群可能是值得的.

您还可以查看Confluent的Replicator,它可能更适合您的需求并且是他们公司产品的一部分.信息有点稀疏,让我知道你是否对它感兴趣我可以向能够告诉你更多相关信息的人介绍(或者当然只是发送邮件给Confluent,这将会找到合适的人选以及).


推荐阅读
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • 我正在使用sql-serverkafka-connect和debezium监视sqlserver数据库,但是当我发布并运行我的wo ... [详细]
  • ConsumerConfiguration在kafka0.9使用JavaConsumer替代了老版本的scalaConsumer。新版的配置如下:bootstrap. ... [详细]
  • mac php错误日志配置方法及错误级别修改
    本文介绍了在mac环境下配置php错误日志的方法,包括修改php.ini文件和httpd.conf文件的操作步骤。同时还介绍了如何修改错误级别,以及相应的错误级别参考链接。 ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 本文介绍了使用Spark实现低配版高斯朴素贝叶斯模型的原因和原理。随着数据量的增大,单机上运行高斯朴素贝叶斯模型会变得很慢,因此考虑使用Spark来加速运行。然而,Spark的MLlib并没有实现高斯朴素贝叶斯模型,因此需要自己动手实现。文章还介绍了朴素贝叶斯的原理和公式,并对具有多个特征和类别的模型进行了讨论。最后,作者总结了实现低配版高斯朴素贝叶斯模型的步骤。 ... [详细]
  • Activiti7流程定义开发笔记
    本文介绍了Activiti7流程定义的开发笔记,包括流程定义的概念、使用activiti-explorer和activiti-eclipse-designer进行建模的方式,以及生成流程图的方法。还介绍了流程定义部署的概念和步骤,包括将bpmn和png文件添加部署到activiti数据库中的方法,以及使用ZIP包进行部署的方式。同时还提到了activiti.cfg.xml文件的作用。 ... [详细]
  • Android日历提醒软件开源项目分享及使用教程
    本文介绍了一款名为Android日历提醒软件的开源项目,作者分享了该项目的代码和使用教程,并提供了GitHub项目地址。文章详细介绍了该软件的主界面风格、日程信息的分类查看功能,以及添加日程提醒和查看详情的界面。同时,作者还提醒了读者在使用过程中可能遇到的Android6.0权限问题,并提供了解决方法。 ... [详细]
  • 大数据Hadoop生态(20)MapReduce框架原理OutputFormat的开发笔记
    本文介绍了大数据Hadoop生态(20)MapReduce框架原理OutputFormat的开发笔记,包括outputFormat接口实现类、自定义outputFormat步骤和案例。案例中将包含nty的日志输出到nty.log文件,其他日志输出到other.log文件。同时提供了一些相关网址供参考。 ... [详细]
  • 本文讨论了在shiro java配置中加入Shiro listener后启动失败的问题。作者引入了一系列jar包,并在web.xml中配置了相关内容,但启动后却无法正常运行。文章提供了具体引入的jar包和web.xml的配置内容,并指出可能的错误原因。该问题可能与jar包版本不兼容、web.xml配置错误等有关。 ... [详细]
  • 目录浏览漏洞与目录遍历漏洞的危害及修复方法
    本文讨论了目录浏览漏洞与目录遍历漏洞的危害,包括网站结构暴露、隐秘文件访问等。同时介绍了检测方法,如使用漏洞扫描器和搜索关键词。最后提供了针对常见中间件的修复方式,包括关闭目录浏览功能。对于保护网站安全具有一定的参考价值。 ... [详细]
  • 本文总结了初学者在使用dubbo设计架构过程中遇到的问题,并提供了相应的解决方法。问题包括传输字节流限制、分布式事务、序列化、多点部署、zk端口冲突、服务失败请求3次机制以及启动时检查。通过解决这些问题,初学者能够更好地理解和应用dubbo设计架构。 ... [详细]
  • 项目运行环境配置及可行性分析
    本文介绍了项目运行环境配置的要求,包括Jdk1.8、Tomcat7.0、Mysql、HBuilderX等工具的使用。同时对项目的技术可行性、操作可行性、经济可行性、时间可行性和法律可行性进行了分析。通过对数据库的设计和功能模块的设计,确保系统的完整性和安全性。在系统登录、系统功能模块、管理员功能模块等方面进行了详细的介绍和展示。最后提供了JAVA毕设帮助、指导、源码分享和调试部署的服务。 ... [详细]
  • .htaccess文件 ... [详细]
author-avatar
他w与他说
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有