当前位置: 首页 > news >正文

Kafka集群扩容(新增一台kafka节点)

  • kafka集群扩容、kafka topic迁移

  • 现有环境

IP组件角色
192.168.17.51kafka01broker1
192.168.17.52kafka02broker2
192.168.17.53kafka03broker3
  • 扩容之后环境
IP组件角色
192.168.17.51kafka01broker1
192.168.17.52kafka02broker2
192.168.17.53kafka03broker3
192.168.17.54kafka04broker4
  • 背景:目前kafka集群只有三台,随着数据量逐渐变大,三台服务器kafka节点不足以支撑正常使用,所以打算在扩容一台kafka节点
  1. kafka扩容步骤:
  • 分发kafka包
scp -r kafka_2.11-1.1.1 root@192.168.17.54:/opt/
  • 创建软连接,赋权限
ln -s kafka_2.11-1.1.1 /opt/kafka
chown -R kafka:kafka kafka
chown -R kafka:kafka kafka_2.11-1.1.1/
  • 修改配置
vim /opt/kafka/config/server.properties

新的节点需要修改下面这些配置

broker.id #集群中是唯一的数字
listeners #本机IP
log.dirs #数据目录,可以多个目录,多目录逗号隔开
zookeeper.connec #zookeeper地址

在这里插入图片描述在这里插入图片描述在这里插入图片描述

  • 启动kafka,并检查是否成功
nohup /bin/sh /opt/kafka/bin/kafka-server-start.sh /opt/kafka/config/server.properties > /dev/null 2>&1 &
jps

在这里插入图片描述

上步骤完成以后kafka集群没有完全扩容成功,因为只扩容了kafka节点,原来有的topic还是在原有的几点上,这台新扩容的还没有分担原有的压力,所以还需要迁移topic

  1. 迁移kafka topic

在原有的集群上,任一一台kafka节点操作

使用kafka提供的工具kafka-reassign-partitions.sh来迁移数据。迁移数据需要分三步做
第一步:生成迁移计划

先手动生成一个topic.json,内容如下。这里topic可以是一个列表

在这里插入图片描述

单个topic迁移

{"topics": [{"topic": "ceshi2"},"version": 1
}

多个topic迁移

{"topics": [{"topic": "ceshi2"},{"topic": "ceshi3"},{"topic": "ceshi4"}],"version": 1
}
  • 执行以下命令 生成迁移计划
./bin/kafka-reassign-partitions.sh --zookeeper 192.168.17.51:2181/kafka --topics-to-move-json-file topic.json --broker-list "1,2,3,4" --generate

–broker-list kafka集群的所有broker.id 我的是从1开始
在这里插入图片描述

  • 查看需要迁移的topic信息
./bin/kafka-topics.sh --describe --zookeeper 192.168.17.52:2181/kafka --topic ceshi2

在这里插入图片描述

新建一个文件reassignment.json
保存上边建议分区信息,注意只复制只复制上述中’Proposed partition reassignment configuration’以下的部分
其中Current partition replica assignment指当前的分区情况,Proposed partition reassignment configuration是计划的分区情况

./bin/kafka-reassign-partitions.sh --zookeeper 192.168.17.51:2181/kafka --reassignment-json-file reassignment.json --execute

在这里插入图片描述

  • 验证1
./bin/kafka-reassign-partitions.sh --zookeeper 192.168.17.51:2181/kafka --reassignment-json-file reassignment.json --verify

在这里插入图片描述

  • 验证2
    可以通过以下命令查看该topic分布在那些节点上,正常是和刚才查到的不一样得,应该会在新扩容得节点上面有
./bin/kafka-topics.sh --describe --zookeeper 192.168.17.52:2181/kafka --topic ceshi2

迁移成功。

http://www.lryc.cn/news/443744.html

相关文章:

  • 作文笔记15 点面结合
  • Spring Boot-国际化(I18N)问题
  • 8. 防火墙
  • C语言循环学习
  • 职业技能大赛-自动化测试笔记(Unitest)分享-3
  • rocky9.2的lvs的NAT模式下的基本使用的详细示例
  • AI健身之俯卧撑计数和姿态矫正-角度估计
  • Java ETL - Apache Beam 简介
  • 使用 Fairseq 进行音频预训练:Train a wav2vec 2.0 base model配置与实现
  • 全面详尽的 PHP 环境搭建教程
  • fiddler抓包06_抓取https请求(chrome)
  • 【在Linux世界中追寻伟大的One Piece】网络命令|验证UDP
  • qt-C++笔记之Q_DECLARE_METATYPE和qRegisterMetaType
  • Shader 中的光源
  • 【django】局域网访问django启动的项目
  • 【计算机组成原理】主存储器深度解析
  • docker在基础镜像上,比如rockylinux,如何配置yum仓库
  • libtorch落地AI项目的一些总结
  • ffmpeg面向对象——参数配置秘密探索及其设计模式
  • 华为eNSP使用详解
  • 一文入门生成式AI(理解ChatGPT的原理)
  • C# 中Faker
  • 数据权限的设计与实现系列9——前端筛选器组件Everright-filter集成框架开发2
  • 鸿蒙Harmony-Next 徒手撸一个日历控件
  • 直播音频解决方案
  • Git基本用法总结
  • SQLite的入门级项目学习记录(四)
  • Docker工作目录迁移
  • 【多维动态规划】64. 最小路径和(面试真题+面试官调整后的题目)
  • Web后端开发技术:RESTful 架构详解