Kafka:Kraft 模式集群部署(无需zookeeper)

1)解压一份 kafka 安装包

[root@hadoop102 software]$ tar -zxvf kafka_2.12-3.0.0.tgz -C 
/opt/module/

2)重命名为 kafka2

[root@hadoop102 module]$ mv kafka_2.12-3.0.0/ kafka2

3)在 hadoop102 上修改/opt/module/kafka2/config/kraft/server.properties 配置文件

[root@hadoop102 kraft]$ vim server.properties

# kafka 的角色(controller 相当于主机、broker 节点相当于从机,主机类似 zk 功能)
process.roles=broker, controller
# 节点 ID
node.id=2

# controller 服务协议别名
controller.listener.names=CONTROLLER

# 全 Controller 列表
controller.quorum.voters=2@hadoop102:9093,3@hadoop103:9093,4@hadoop104:9093

# 不同服务器绑定的端口
listeners=PLAINTEXT://:9092,CONTROLLER://:9093

# broker 服务协议别名
inter.broker.listener.name=PLAINTEXT

# broker 对外暴露的地址
advertised.Listeners=PLAINTEXT://hadoop102:9092

# 协议别名到安全协议的映射
listener.security.protocol.map=CONTROLLER:PLAINTEXT,PLAINTEXT:PLAINTEXT,SSL:SSL,SASL_PLAINTEXT:SASL_PLAINTEXT,SASL_SSL:SASL_SSL

# kafka 数据存储目录
log.dirs=/opt/module/kafka2/data

4)分发 kafka2

[root@hadoop102 module]$ xsync kafka2/

⚫ 在 hadoop103 和 hadoop104 上 需 要 对 node.id 相应改变 , 值 需 要 和 controller.quorum.voters 对应。

⚫ 在 hadoop103 和 hadoop104 上需要 根据各自的主机名称,修改相应的 advertised.Listeners 地址。

5)初始化集群数据目录

(1)首先生成存储目录唯一 ID。

[root@hadoop102 kafka2]$ bin/kafka-storage.sh random-uuid

J7s9e8PPTKOO47PxzI39VA

 (2)用该 ID 格式化 kafka 存储目录(三台节点)。

[root@hadoop102 kafka2]$ bin/kafka-storage.sh format -t J7s9e8PPTKOO47PxzI39VA -c /opt/module/kafka2/config/kraft/server.properties

[root@hadoop103 kafka2]$ bin/kafka-storage.sh format -t J7s9e8PPTKOO47PxzI39VA -c /opt/module/kafka2/config/kraft/server.properties

[root@hadoop104 kafka2]$ bin/kafka-storage.sh format -t J7s9e8PPTKOO47PxzI39VA -c /opt/module/kafka2/config/kraft/server.properties

6)启动 kafka 集群

[root@hadoop102 kafka2]$ bin/kafka-server-start.sh -daemon config/kraft/server.properties

[root@hadoop103 kafka2]$ bin/kafka-server-start.sh -daemon config/kraft/server.properties

[root@hadoop104 kafka2]$ bin/kafka-server-start.sh -daemon config/kraft/server.properties

7)停止 kafka 集群

[root@hadoop102 kafka2]$ bin/kafka-server-stop.sh
[root@hadoop103 kafka2]$ bin/kafka-server-stop.sh
[root@hadoop104 kafka2]$ bin/kafka-server-stop.sh

Kafka-Kraft 集群启动停止脚本

1)在/home/wx/bin 目录下创建文件 kf2.sh 脚本文件 

[root@hadoop102 bin]$ vim kf2.sh

脚本如下:

#! /bin/bash
case $1 in
"start"){
 for i in hadoop102 hadoop103 hadoop104
 do
 echo " --------启动 $i Kafka2-------"
 ssh $i "/opt/module/kafka2/bin/kafka-server-start.sh -
daemon /opt/module/kafka2/config/kraft/server.properties"
 done
};;
"stop"){
 for i in hadoop102 hadoop103 hadoop104
 do
 echo " --------停止 $i Kafka2-------"
 ssh $i "/opt/module/kafka2/bin/kafka-server-stop.sh "
 done
};;
esac

2)添加执行权限

[root@hadoop102 bin]$ chmod +x kf2.sh

3)启动集群命令

[root@hadoop102 ~]$ kf2.sh start

4)停止集群命令

[root@hadoop102 ~]$ kf2.sh stop
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员无羡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值