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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 充分条件和必要条件的口诀_充分必要条件的例子100个

    充分条件和必要条件的口诀_充分必要条件的例子100个充分条件:如果条件A是结论B的充分条件:A与其他条件是并连关系,即A、C、D….中任意一个存在都可以使得B成立(就像是个人英雄主义),如下图:<imgsrc="https://p

    2022年8月6日
    6
  • disk boot failure ,insert sysytem disk and press enter解决方法

    disk boot failure ,insert sysytem disk and press enter解决方法故障分析与处理从现象上看硬盘可能是损坏了,如果在无法启动前的最后一次关机是按照正常程序退出。将硬盘拆下来连接到另外一台机器上,开机启动后进入CMOS设置主菜单,选择“IDE HDD AUTO DETECTION”栏,检测到硬盘参数,能正常进入硬盘。将硬盘装回到原来的机器上,进入CMOS设置后能自动检测到硬盘的参数,恢复了正常启动。关机时按照正常程序退出,而下一次开机时无法用硬盘启动并且无

    2022年7月13日
    17
  • Java安全之C3P0链利用与分析

    Java安全之C3P0链利用与分析0x00前言在一些比较极端情况下,C3P0链的使用还是挺频繁的。0x01利用方式利用方式在C3P0中有三种利用方式httpbaseJNDIHEX

    2021年12月13日
    42
  • 《chkconfig命令》-linux命令五分钟系列之四

    《chkconfig命令》-linux命令五分钟系列之四

    2021年9月8日
    60
  • 风格迁移综述

    风格迁移综述风格迁移综述 0 引言 1 基于图像迭代的风格迁移方法 1 1 基于最大均值差异的风格迁移 1 2 基于马尔科夫随机场的风格迁移 限制条件较多 有时视觉效果不是很好 1 3 基于深度图像类比的风格迁移 2 基于模型迭代的风格迁移算法 2 1 基于生成模型的风格迁移 2 2 基于图像重构解码器的风格迁移 3 应用举例 4 未来研究方向 5 参考文献推荐论文 Y Jing Y Yang Z Feng J Ye Y YuandM Song NeuralStyleT AReview

    2025年12月8日
    2
  • 最小二乘法详细推导过程

    最小二乘法详细推导过程转载自:http://blog.csdn.net/marsjohn/article/details/54911788在数据的统计分析中,数据之间即变量x与Y之间的相关性研究非常重要,通过在直角坐标系中做散点图的方式我们会发现很多统计数据近似一条直线,它们之间或者正相关或者负相关。虽然这些数据是离散的,不是连续的,我们无法得到一个确定的描述这种相关性的函数方程,但既然在直角坐标系中数据分布接近一…

    2022年5月13日
    34

发表回复

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

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