当前位置:首页 > PS视频 > 正文内容

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

编辑2个月前 (04-27)PS视频8

一、集群规划(生产最小推荐 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.cryp6.com/?id=125

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

视频里的水印怎么去除干净?6种方法亲测有效,简单又无痕

视频里的水印怎么去除干净?6种方法亲测有效,简单又无痕

根据2026年行业报告显示,视频去水印工具市场规模已达43.8亿元,年增长率超21%,其中个人创作者占比59%,企业级客户采购量三年翻番。无论是剪辑短视频、二次创作素材,还是整理工作资料,“水印碍事”都成了高频痛点。要么遮挡关键信息,要么影响画面美感,更有甚者会被平台判定为非原创内容。今天分享6种亲...

微信记录彻底备份教程,换手机一键迁移

全程不用复杂操作,老人也能看懂,每一步都对应截图位置。一、手机直接互传(换手机首选,免费最快)适合:旧手机换新手机、当场迁移所有聊天1新旧手机都连上同一个 WiFi,登录同一个微信号2打开微信 → 点【我】→【设置】3找到【通用】→【聊天记录迁移与备份】4选择【迁移聊天记录到另一台设备】5旧手机勾选...

 iPhone如何快速整理你的相册 iPhone怎么备份照片比较方便

iPhone如何快速整理你的相册 iPhone怎么备份照片比较方便

一、iPhone如何快速整理你的相册当手机中的照片或视频太多,管理变得越来越麻烦时,我们可以利用相册中自带的功能对照片进行分类,下面看看iPhone如何快速整理相册。1、打开手机中的【照片】,点击底部导航栏中的【相簿】按钮。在页面左上方点击【+】号图标,在弹出的列表中选择【新建相簿】,如下图所示。图...

云空间不够用?解决办法

一、清理无用数据(最快见效)删除重复照片、模糊截图、过期视频、无用录屏,这类文件占用空间最大。清理软件缓存、垃圾文件、过期安装包、压缩包。删掉不再需要的聊天记录、旧文件、离线缓存内容。二、本地备份,释放云端空间用电脑有线连接手机,把照片、视频、大文件批量保存到电脑硬盘。重要资料存电脑本地,不用全部上...

如何关闭手机、电脑的云同步功能

如何关闭手机、电脑的云同步功能

下面分手机(iOS / 安卓主流品牌)和电脑(Windows/Mac),一步步教你关闭云同步(可选择性关,也可全关),以及关闭后如何防止数据被自动恢复 / 覆盖。一、苹果手机(iPhone/iPad):关闭 iCloud 同步1)选择性关闭(推荐:只关照片 / 文档,保留联系人等)打开 设置 → 点...

 如何在电脑上关闭云同步功能?

如何在电脑上关闭云同步功能?

下面分 Windows 和 Mac,把系统自带云同步和 ** 常见第三方云盘(OneDrive/iCloud/ 百度网盘)** 都一次性关掉,适合你要 “改记录不被覆盖” 的场景。Windows 电脑:关闭所有云同步1. 先关 OneDrive(最关键)右下角任务栏,找到蓝色云朵 OneDrive...

发表评论

访客

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