本文档应用环境为 kafka-0.8.2.0, 其余版本请先行测试

场景

线上很多 kafka 的 topic 的副本数为1,这样的设置丧失了 kafka 高可用的特性,所以我们需要把 topic 的副本数至少设置为2(当前3台 kafka)

我们使用 kafkat 这个工具,这个工具是 ruby 写的,所以我们先安装 ruby 环境

参考 https://ruby-china.org/wiki/rvm-guide

这时候你应该已经由了 gem 命令

继续参考https://github.com/airbnb/kafkat 把 kafkat 装上, 并配置好你的 kafka 环境参数到 ~/.kafkatcfg

实操

我们修改 topic 的 replicas 为2

[root@001 kafka]# kafkat partitions IM_APP_BINSPECT_MSG_TOPIC
Topic       Partition   Leader      Replicas                        ISRs
IM_APP_BINSPECT_MSG_TOPIC   0       2       [2]                         [2]
IM_APP_BINSPECT_MSG_TOPIC   1       3       [3]                         [3]
IM_APP_BINSPECT_MSG_TOPIC   2       1       [1]                         [1]
IM_APP_BINSPECT_MSG_TOPIC   3       2       [2]                         [2]
IM_APP_BINSPECT_MSG_TOPIC   4       3       [3]                         [3]
IM_APP_BINSPECT_MSG_TOPIC   5       1       [1]                         [1]
IM_APP_BINSPECT_MSG_TOPIC   6       2       [2]                         [2]
IM_APP_BINSPECT_MSG_TOPIC   7       3       [3]                         [3]
IM_APP_BINSPECT_MSG_TOPIC   8       1       [1]                         [1]
IM_APP_BINSPECT_MSG_TOPIC   9       2       [2]                         [2]
IM_APP_BINSPECT_MSG_TOPIC   10      3       [3]                         [3]
IM_APP_BINSPECT_MSG_TOPIC   11      1       [1]                         [1]
IM_APP_BINSPECT_MSG_TOPIC   12      2       [2]                         [2]
IM_APP_BINSPECT_MSG_TOPIC   13      3       [3]                         [3]
IM_APP_BINSPECT_MSG_TOPIC   14      1       [1]                         [1]
IM_APP_BINSPECT_MSG_TOPIC   15      2       [2]                         [2]
IM_APP_BINSPECT_MSG_TOPIC   16      3       [3]                         [3]
IM_APP_BINSPECT_MSG_TOPIC   17      1       [1]                         [1]
IM_APP_BINSPECT_MSG_TOPIC   18      2       [2]                         [2]
IM_APP_BINSPECT_MSG_TOPIC   19      3       [3]                         [3]
[root@001 kafka]# kafkat set-replication-factor IM_APP_BINSPECT_MSG_TOPIC --newrf 2 --brokers 1,2,3
This operation executes the following assignments:
Topic       Partition   Replicas
IM_APP_BINSPECT_MSG_TOPIC   0       [21]
IM_APP_BINSPECT_MSG_TOPIC   1       [32]
IM_APP_BINSPECT_MSG_TOPIC   2       [13]
IM_APP_BINSPECT_MSG_TOPIC   3       [21]
IM_APP_BINSPECT_MSG_TOPIC   4       [32]
IM_APP_BINSPECT_MSG_TOPIC   5       [13]
IM_APP_BINSPECT_MSG_TOPIC   6       [21]
IM_APP_BINSPECT_MSG_TOPIC   7       [32]
IM_APP_BINSPECT_MSG_TOPIC   8       [13]
IM_APP_BINSPECT_MSG_TOPIC   9       [21]
IM_APP_BINSPECT_MSG_TOPIC   10      [32]
IM_APP_BINSPECT_MSG_TOPIC   11      [13]
IM_APP_BINSPECT_MSG_TOPIC   12      [21]
IM_APP_BINSPECT_MSG_TOPIC   13      [32]
IM_APP_BINSPECT_MSG_TOPIC   14      [13]
IM_APP_BINSPECT_MSG_TOPIC   15      [21]
IM_APP_BINSPECT_MSG_TOPIC   16      [32]
IM_APP_BINSPECT_MSG_TOPIC   17      [13]
IM_APP_BINSPECT_MSG_TOPIC   18      [21]
IM_APP_BINSPECT_MSG_TOPIC   19      [32]
Proceed (y/n)?
y
Beginning.
Started.
[root@001 kafka]# kafkat partitions IM_APP_BINSPECT_MSG_TOPIC
Topic       Partition   Leader      Replicas                        ISRs
IM_APP_BINSPECT_MSG_TOPIC   0       2       [21]                          [2]
IM_APP_BINSPECT_MSG_TOPIC   1       3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   2       1       [13]                          [1]
IM_APP_BINSPECT_MSG_TOPIC   3       2       [21]                          [2]
IM_APP_BINSPECT_MSG_TOPIC   4       3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   5       1       [13]                          [1]
IM_APP_BINSPECT_MSG_TOPIC   6       2       [21]                          [2]
IM_APP_BINSPECT_MSG_TOPIC   7       3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   8       1       [13]                          [1]
IM_APP_BINSPECT_MSG_TOPIC   9       2       [21]                          [2]
IM_APP_BINSPECT_MSG_TOPIC   10      3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   11      1       [13]                          [1]
IM_APP_BINSPECT_MSG_TOPIC   12      2       [21]                          [2]
IM_APP_BINSPECT_MSG_TOPIC   13      3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   14      1       [13]                          [1]
IM_APP_BINSPECT_MSG_TOPIC   15      2       [21]                          [2]
IM_APP_BINSPECT_MSG_TOPIC   16      3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   17      1       [13]                          [1]
IM_APP_BINSPECT_MSG_TOPIC   18      2       [21]                          [2]
IM_APP_BINSPECT_MSG_TOPIC   19      3       [32]                          [3]

解释

上面一共执行了3个命令

  1. kafkat partitions IM_APP_BINSPECT_MSG_TOPIC   查看 topic 的分区情况
  2. kafkat set-replication-factor IM_APP_BINSPECT_MSG_TOPIC --newrf 2 --brokers 1,2,3   重新设置副本数为2  --newrf 2  , 你有几个 broker就在--brokers 后面指定
  3. kafkat partitions IM_APP_BINSPECT_MSG_TOPIC    检查是否生效

根据 topic 数据量最后完成的时间也不同(大概几分钟)

这是最后的完成情况

[root@001 kafka]# kafkat partitions IM_APP_BINSPECT_MSG_TOPIC
Topic       Partition   Leader      Replicas                        ISRs
IM_APP_BINSPECT_MSG_TOPIC   0       2       [21]                          [21]
IM_APP_BINSPECT_MSG_TOPIC   1       3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   2       1       [13]                          [13]
IM_APP_BINSPECT_MSG_TOPIC   3       2       [21]                          [21]
IM_APP_BINSPECT_MSG_TOPIC   4       3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   5       1       [13]                          [13]
IM_APP_BINSPECT_MSG_TOPIC   6       2       [21]                          [21]
IM_APP_BINSPECT_MSG_TOPIC   7       3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   8       1       [13]                          [13]
IM_APP_BINSPECT_MSG_TOPIC   9       2       [21]                          [21]
IM_APP_BINSPECT_MSG_TOPIC   10      3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   11      1       [13]                          [13]
IM_APP_BINSPECT_MSG_TOPIC   12      2       [21]                          [21]
IM_APP_BINSPECT_MSG_TOPIC   13      3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   14      1       [13]                          [13]
IM_APP_BINSPECT_MSG_TOPIC   15      2       [21]                          [21]
IM_APP_BINSPECT_MSG_TOPIC   16      3       [32]                          [32]
IM_APP_BINSPECT_MSG_TOPIC   17      1       [13]                          [13]
IM_APP_BINSPECT_MSG_TOPIC   18      2       [21]                          [21]
IM_APP_BINSPECT_MSG_TOPIC   19      3       [32]                          [32]
 

使用 kafkat 在线扩缩容 kafka replicas的更多相关文章

  1. 构建Docker平台【第四篇】创建服务及扩缩容等操作

    第一步:创建服务 1. 配置 nginx 的 yaml 文件 apiVersion: extensions/v1beta1 kind: Deployment metadata: name: my-ng ...

  2. 通过Dapr实现一个简单的基于.net的微服务电商系统(十一)——一步一步教你如何撸Dapr之自动扩/缩容

    上一篇我们讲到了dapr提供的bindings,通过绑定可以让我们的程序轻装上阵,在极端情况下几乎不需要集成任何sdk,仅需要通过httpclient+text.json即可完成对外部组件的调用,这样 ...

  3. Docker Swarm(七)Scale 扩(缩)容服务

    扩(缩)容服务 扩容服务 Service还提供了复制(类似kubernetes里的副本)功能.可以通过 docker service scale 命令来设置服务中容器的副本数: docker serv ...

  4. 【kubevirt】VirtualMachineInstanceReplicaSet(vmis)-扩缩容-弹性伸缩

    @ 目录 概述/理解 使用场景 创建vmis 扩缩容 弹性伸缩 方法1 方法2 概述/理解 VirtualMachineInstanceReplicaSet(vmis)确保指定数量的 VirtualM ...

  5. Airbnb的动态kubernetes集群扩缩容

    Airbnb的动态kubernetes集群扩缩容 本文介绍了Airbnb的集群扩缩容的演化历史,以及当前是如何通过Cluster Autoscaler 实现自定义扩展器的.最重要的经验就是Airbnb ...

  6. k8s手动扩缩容

    1. 查询deploy副本数,ready数表示副本数 kubectl get deploy 2.通过命令直接扩容或者缩容,--replicas=1表示把my-dep缩容到副本数1,--replicas ...

  7. Kubernetes 监控:Prometheus Adpater =》自定义指标扩缩容

    使用 Kubernetes 进行容器编排的主要优点之一是,它可以非常轻松地对我们的应用程序进行水平扩展.Pod 水平自动缩放(HPA)可以根据 CPU 和内存使用量来扩展应用,前面讲解的 HPA 章节 ...

  8. 三十三、HPA实现自动扩缩容

    通过HPA实现业务应用的动态扩缩容 HPA控制器介绍 当系统资源过高的时候,我们可以使用如下命令来实现 Pod 的扩缩容功能 $ kubectl -n luffy scale deployment m ...

  9. Knative 基本功能深入剖析:Knative Serving 自动扩缩容 Autoscaler

    Knative Serving 默认情况下,提供了开箱即用的快速.基于请求的自动扩缩容功能 - Knative Pod Autoscaler(KPA).下面带你体验如何在 Knative 中玩转 Au ...

随机推荐

  1. Mac版Java安装与配置

    一.下载并安装JDK http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 双击下载的 ...

  2. BP神经网络的数学常识

    输入数据X1-Xn. 输入层和隐层之间的权Wji 隐层的输入数据为:∑iwjixi 隐层的输出数据为:yj = f(∑iwjixi).其中f(x)= 隐层的输入数据为:∑jwkjyj 隐层的输出数据为 ...

  3. 52.tableViewCell重用机制避免重复显示问题

    表刷新超出页面显示的内容会重复出现 -(UITableViewCell*)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSInd ...

  4. centos7 虚拟机安装docker-ce-17.09

    1.创建虚拟机使用iso镜像centos-x86_64-7.3.1611 2.安装centos选择桌面版 3.配置命令行环境,网卡(见博客另一篇文章) 4.安装container-selinux-2. ...

  5. Lecture 5

  6. 2018.11.01 NOIP训练 树的排列(树形dp)

    传送门 跟这道题差不多. 只不过是让权值小的儿子做权值大的儿子的父亲而已. 代码

  7. 文字过多以省略号代替,放在文字上会显示title信息提示

    第一种: <td style="text-align:left; word-wrap:break-word;" title="${b.remarks}"& ...

  8. 03 编写URL规则

    3-1 URL编写规则 # 在每个App中设置独立的静态资源和模板文件并添加一个空白内容的urls.py文件. # 当程序收到用户请求的时候,首先在根目录的urls.py查找该URL属于哪个APP,然 ...

  9. 学以致用三----centos7.2基本环境补充

    补充: 在上一篇里,加时间戳 echo ‘export HISTTIMEFORMAT ="%F %T `whoami`" ’ >> /etc/profile sourc ...

  10. Effective C++ 随笔(4)

    条款21:必须返回对象时,别妄想返回其reference 例子: Raional类可以执行有理数的一些运算,并且使用heap内存申请 并且其operator*函数为 const Rational&am ...