当前位置:首页 > 修改聊天记录 > 正文内容

Kafka 4.1.1 生产集群部署完整指南(手把手教程)

网页编辑2个月前 (04-27)修改聊天记录123

一、集群规划(生产最小推荐 3 节点)

示例 3 节点:
  • kafka-1:192.168.1.101

  • kafka-2:192.168.1.102

  • kafka-3:192.168.1.103

角色:所有节点同时为 broker + controller(生产常用)

二、环境准备(所有节点)

1. 系统要求

  • Linux(CentOS 7+/Ubuntu 20.04+)

  • Java 17+(Kafka 4.1 强制 Java 17)Apache Kafka

2. 安装 Java(所有节点)

bash
运行
# CentOSsudo yum install -y java-17-openjdk# Ubuntusudo apt install -y openjdk-17-jdk# 验证java -version

3. 关闭防火墙 / 放行端口

bash
运行
# 关闭(或放行 9092、9093)sudo systemctl stop firewalldsudo systemctl disable firewalld

4. 创建用户(推荐非 root 运行)

bash
运行
sudo useradd kafkasudo passwd kafkasudo mkdir -p /opt/kafka /data/kafka-logs /data/kafka-metasudo chown -R kafka:kafka /opt/kafka /data/kafka-logs /data/kafka-meta

三、下载安装 Kafka 4.1.1(所有节点)

bash
运行
# 切换 kafka 用户su - kafka# 下载(Scala 2.13)wget https://downloads.apache.org/kafka/4.1.1/kafka_2.13-4.1.1.tgz# 解压到 /opt/kafkatar -zxf kafka_2.13-4.1.1.tgz -C /opt/mv /opt/kafka_2.13-4.1.1/* /opt/kafka/rm -rf /opt/kafka_2.13-4.1.1# 目录结构/opt/kafka
├── bin/
├── config/
└── logs/

四、配置 server.properties(所有节点,关键)

节点 1(kafka-1,192.168.1.101)
bash
运行
vim /opt/kafka/config/server.properties
ini
# 基础node.id=1process.roles=broker,controller# 监听listeners=PLAINTEXT://0.0.0.0:9092,CONTROLLER://0.0.0.0:9093advertised.listeners=PLAINTEXT://192.168.1.101:9092listener.security.protocol.map=PLAINTEXT:PLAINTEXT,CONTROLLER:PLAINTEXTinter.broker.listener.name=PLAINTEXT# KRaft 仲裁controller.quorum.voters=1@192.168.1.101:9093,2@192.168.1.102:9093,3@192.168.1.103:9093controller.listener.names=CONTROLLER# 数据目录log.dirs=/data/kafka-logsmetadata.log.dir=/data/kafka-meta# 生产默认num.partitions=3default.replication.factor=2min.insync.replicas=1log.retention.hours=168log.segment.bytes=1073741824
节点 2(kafka-2,192.168.1.102)
仅改 3 处:
ini
node.id=2advertised.listeners=PLAINTEXT://192.168.1.102:9092
节点 3(kafka-3,192.168.1.103)
ini
node.id=3advertised.listeners=PLAINTEXT://192.168.1.103:9092
注意:KRaft 不再需要 zookeeper.connect删掉或注释

五、初始化集群(仅一次,任意节点执行)

1. 生成集群 UUID

bash
运行
/opt/kafka/bin/kafka-storage.sh random-uuid# 输出类似:6UlNw0IfR5-mEArqnPh1aQ(记下来)

2. 格式化所有节点存储(每个节点都要执行,用上面的 UUID)

bash
运行
# 节点 1/opt/kafka/bin/kafka-storage.sh format \
  -t 6UlNw0IfR5-mEArqnPh1aQ \
  -c /opt/kafka/config/server.properties# 节点 2/opt/kafka/bin/kafka-storage.sh format \
  -t 6UlNw0IfR5-mEArqnPh1aQ \
  -c /opt/kafka/config/server.properties# 节点 3/opt/kafka/bin/kafka-storage.sh format \
  -t 6UlNw0IfR5-mEArqnPh1aQ \
  -c /opt/kafka/config/server.properties
```{insert\_element\_1\_}---## 六、配置 systemd 服务(所有节点,生产必做)```bashsudo vim /etc/systemd/system/kafka.service
ini
[Unit]Description=Apache Kafka 4.1.1 (KRaft)After=network.target[Service]Type=simpleUser=kafkaGroup=kafkaEnvironment="KAFKA_HOME=/opt/kafka"Environment="PATH=/opt/kafka/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin"WorkingDirectory=/opt/kafkaExecStart=/opt/kafka/bin/kafka-server-start.sh /opt/kafka/config/server.propertiesExecStop=/opt/kafka/bin/kafka-server-stop.shRestart=on-failureRestartSec=5[Install]WantedBy=multi-user.target
加载并设置开机自启:
bash
运行
sudo systemctl daemon-reloadsudo systemctl enable kafka

七、启动集群(所有节点)

bash
运行
sudo systemctl start kafka# 查看状态sudo systemctl status kafka# 查看日志(排错用)tail -f /opt/kafka/logs/server.log

八、验证集群(任意节点)

1. 查看 KRaft 控制器状态

bash
运行
/opt/kafka/bin/kafka-metadata-quorum.sh \
  --bootstrap-controller=192.168.1.101:9093 \
  describe --replication
能看到 leader、follower 即正常

2. 创建测试 Topic

bash
运行
/opt/kafka/bin/kafka-topics.sh \
  --create --topic test-topic \
  --bootstrap-server 192.168.1.101:9092 \
  --partitions 3 --replication-factor 2

3. 生产 / 消费测试

bash
运行
# 生产/opt/kafka/bin/kafka-console-producer.sh \
  --topic test-topic --bootstrap-server 192.168.1.101:9092# 消费(新窗口)/opt/kafka/bin/kafka-console-consumer.sh \
  --topic test-topic --from-beginning \
  --bootstrap-server 192.168.1.101:9092

九、生产环境关键优化(必做)

  1. JVM 内存(默认太小)

bash
运行
vim /opt/kafka/bin/kafka-server-start.sh# 修改export KAFKA_HEAP_OPTS="-Xms4G -Xmx4G"  # 生产按内存调整,一般 4~8G
  1. 文件句柄 / 线程数

bash
运行
sudo vim /etc/security/limits.conf
kafka soft nofile 65535kafka hard nofile 65535kafka soft nproc 65535kafka hard nproc 65535
  1. 磁盘log.dirs 用独立高速磁盘,不要和系统盘混放


十、常用运维命令

bash
运行
# 停止sudo systemctl stop kafka# 查看 Topic 列表/opt/kafka/bin/kafka-topics.sh --list --bootstrap-server 192.168.1.101:9092# 查看 Topic 详情/opt/kafka/bin/kafka-topics.sh --describe --topic test-topic --bootstrap-server 192.168.1.101:9092


扫描二维码推送至手机访问。

版权声明:本文由手机数据加工厂发布,如需转载请注明出处。

本文链接:https://www.gaijilu.com/?id=173

“Kafka 4.1.1 生产集群部署完整指南(手把手教程)” 的相关文章

普通版袁大头真假鉴别/手把手教你银元鉴定

普通版袁大头真假鉴别/手把手教你银元鉴定

  一块普通版袁大头行情在800-1500左右,今天我们来看看它的真假鉴别一、银质辨伪:辩别银元的真假,首先从辨识银质的真假开始,银元连银都不是怎么能称为银元呢,从古有“银子发白眼睛发黑”之说,就是说真币越擦越白,晶莹锃亮,表里一致,反之一擦就发黑或灰白,如镀银所制,则有一种浮躁感。二、...

苹果iPhone+Mac如何开启WiFi+蓝牙

下面直接给你「一步到位」的极简版,照着点就行(为了隔空投送,**Wi‑Fi 和蓝牙都要开,不需要连同一个 Wi‑Fi 也能投送**)。 --- iPhone 打开 Wi‑Fi + 蓝牙(两种方法) 方法1:控制中心(最快) - 全面屏 iPhone(带刘海):**右上角往下滑**...

有哪些软件可以实现手机和电脑之间的高效数据管理?

有哪些软件可以实现手机和电脑之间的高效数据管理?

下面按「苹果生态 / 安卓+Windows / 全平台通用」三类,给你整理**真正能落地、高效不乱的手机↔电脑数据管理软件**,每款讲清楚:**能干啥、适合谁、优缺点**。 --- ## 一、iPhone + Mac(苹果生态最优) ### 1. 系统自带:隔空投送 + 访达(免费,首...

 如何使用iMazing进行照片备份?

如何使用iMazing进行照片备份?

一、准备工作电脑安装 iMazing(支持 Mac / Windows)用原装数据线把 iPhone 连到电脑手机解锁,信任此电脑二、方法 A:单独导出照片(最常用)1. 进入照片界面iMazing 识别手机后,左侧点击照片iMazing2. 选择要备份的照片按 Ctrl+A 全选,或手动勾选可按相...

 如何清理手机中的重复文件?

如何清理手机中的重复文件?

一、安卓(华为 / 小米 / OPPO/vivo)1. 一键清理所有重复文件(照片 + 文档 + 安装包)打开手机管家 / 安全中心 /i 管家进入清理加速 / 空间清理扫描完找到重复文件 → 去清理全选重复项 → 删除(自动保留一份)2. 相册重复照片 / 视频(最占空间)华为:相册 → 相册管理...

什么是科技数据?

科技数据,本质上是通过电子设备(手机、电脑、服务器等)采集、存储、传输和处理的各类信息的集合,以二进制代码的形式存在,是数字科技的基础。与我们传统认知中的“文件”不同,科技数据的范畴更广泛,既包括我们主动创建的照片、文档、视频(主动数据),也包括设备运行时自动生成的缓存、日志、定位信息(被动数据);...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。