Kafka集群扩容「建议收藏」

Kafka集群扩容「建议收藏」Kafka集群的服务发现是有zk实现的,因此想kafka集群添加新的broker就非常容易。我们只需要为新的broker设置一个唯一的broker.id,然后启动新增的kafka就行。Kafka集群会自动发现新增的broker并同步原数据,包括当前集群有哪些topics以及topics的分区信息等。但是我们需要的注意的一点,新增的broker不能分担之前已经创建的topic的负载,必须手动执行…

大家好,又见面了,我是你们的朋友全栈君。

Kafka集群的服务发现是有zk实现的,因此想kafka集群添加新的broker就非常容易。我们只需要为新的broker设置一个唯一的broker.id, 然后启动新增的kafka就行。Kafka集群会自动发现新增的broker并同步原数据,包括当前集群有哪些topics以及topics的分区信息等。

但是我们需要的注意的一点,新增的broker不能分担之前已经创建的topic的负载,必须手动执行重新分区才能从为新增broker添加之前的已经存在的topics服务。当然如果不执行重新分组,之后新添加的topics会自动将负载分担到新broker上。

Kafka提供的重分区工具是kakfa-reassign-partitions.sh(bat),默认在<kafka_install_dir>\bin, 例如,
在这里插入图片描述

分区重新分配工具可以以3种互斥模式运行:

--generate:在此模式下,给定主题列表和代理列表,该工具会生成候选重新​​分配,以将指定主题的所有分区移动到新代理。此选项仅提供了一种方便的方法,可在给定主题和目标代理列表的情况下生成分区重新分配计划。
--execute:在此模式下,该工具根据用户提供的重新分配计划启动分区的重新分配。(使用--reassignment-json-file选项)。这可以是由管理员手工制作的自定义重新分配计划,也可以使用--generate选项提供
--verify:在此模式下,该工具将验证最后一次--execute期间列出的所有分区的重新分配状态。状态可以是成功完成,失败或正在进行中

操作

我先只有一个broker0, 然后创建了yqtopic1和yqtopic2两个topic, 这两个topic都是2个分区,一个副本(一个broker上副本机制效果不大,只是为了演示)
1, 第一步生成重分区文件
创建一个要重分区的topic文件 yqToMoveTopics.json

{ 
   "topics": [{ 
   "topic": "yqtoipc1"},

            { 
   "topic": "yqtopic2"}],

"version":1
}
./kafka-reassign-partitions.sh --zookeeper localhost:2181 --topics-to-move-json-file yqToMoveTopics.json --broker-list "0,1" --generate

2, 执行重分区

./kafka-reassign-partitions.sh --zookeeper localhost:2181 --reassignment-json-file /opt/reassign-partitions.json --execute

3, 验证重分区成功

./kafka-reassign-partitions.sh --zookeeper localhost:2181 --reassignment-json-file /opt/reassign-partitions.json  --verify

先创建对象的topic

在这里插入图片描述

启动broker2后,重新分配分区
在这里插入图片描述

具体可以看截图消息。 因为我的topic数据很少,所以可以快速完全重新分区,但是实际生产系统,我们一定要选择业务空闲期执行,而且数据量大的话会执行很长时间。

备注:kafka还提供重分区时限制带宽以保证生产系统平稳。

官方文档:http://kafka.apache.org/10/documentation.html#rep-throttle
kafka-reassign-partitions.sh –zookeeper myhost:2181–execute –reassignment-json-file bigger-cluster.json —throttle 50000000

这样当执行重分区时,你会发现he throttle limit was set to 50000000 B/s, 也就是速率被限制在每秒50000000字节。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/145876.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Centos部署Sonarqube代码质量管理平台

    Centos部署Sonarqube代码质量管理平台

    2021年6月1日
    90
  • vuex中mapGetters「建议收藏」

    vuex中mapGetters「建议收藏」vuex为了更快捷解决组件之间相互传值问题不划分模块结构目录index.js:importVuefrom’vue’importVuexfrom’vuex’importrouterfrom’@/router’import{getToken,setToken,removeToken}from’@/common/utils/auth’import{getInfo,getDeptUserTreeList,initGetToke…

    2022年6月6日
    37
  • 用手机当电脑摄像头的方法有哪些_电脑摄像头可以连接手机吗

    用手机当电脑摄像头的方法有哪些_电脑摄像头可以连接手机吗原文链接:https://cry33.com/archives/295.html有时我们的台式机需要用到摄像头,然而很多台式机并没有摄像头。莫非要花钱买一个?其实大可不必,一部智能手机和一款软件即可

    2022年8月5日
    7
  • 力争群雄:2012年度IT博客大赛100强脱颖而出[通俗易懂]

    力争群雄:2012年度IT博客大赛100强脱颖而出[通俗易懂]2012年度IT博客大赛于11月20日圆满结束。这一所谓的“海选”阶段为期33天,引无数网友和博主翘首以待,来源包括51CTO、独立个人博客、其他博客服务托管商,以及今年评选新增加的分类如独立博客、学生博客和团队博客等众多博主共同参加了这一角逐,其中100位实力雄厚和人气充盈的博主获得了前100强的殊荣。他们占据了25万张票选中的8成以上份量,并将为2012年度IT博客50…

    2022年7月21日
    13
  • Python自动化运维之路-01

    Python自动化运维之路-01python的主要应用python的擅长领域学python有没有前途?python的语言排名语言选择运维会了开发后可以干什么?python的最大优势就是什么都能做。课程概述毕业目标周五

    2022年7月4日
    30
  • java volatile详解

    java volatile详解本篇来自java并发编程实战关于volatile的总结。要说volatile,先得明白内存可见性。那我们就从内存可见性说起。一、内存可见性可见性是一种复杂的属性,因为可见性中的错误总是会违背我们的直觉。在单线程环境中,如果向某个变量先写入值,然后在没有其他写入操作的情况下读取这个变量,那么总能得到相同的值。这看起来很自然。然而,当读操作和写操作在不同的线程中执行时,情况却并非如此,这听

    2022年7月18日
    22

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号