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

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

一、集群规划(生产最小推荐 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 生产集群部署完整指南(手把手教程)” 的相关文章

微信电脑端聊天记录迁移到手机步骤

微信电脑端聊天记录迁移到手机步骤

在电脑上将聊天记录迁移到手机步骤打开电脑版微信,并登录您的微信账号。点击微信界面左下角的三条横线图标在向上弹框里面选择“迁移与备份”。      然后在弹窗中选择“迁移”此处不要急于迁移,否则数据太多,选择下面“迁移部分聊天记录”然后就选择对应的某个人那可,再点开始。注...

如何与客服对话

如何找到客服,有两种方式。一种是在本站的任意页面右下角找到悬浮的“在线客服”,点击即可与客服对话,此办法的好处是不需要添加其它通信方式,可以直接对话。二种是,添加客服微信:gaijilu-com。复制进入微信添加好友即可对话(不需要等客服通过验证即可发消息)。...

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

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

关闭这几个设置,手机瞬间杜绝监听偷窥

1. 关闭多余定位权限所有无关 APP,全部关掉定位只给地图、外卖临时用拒绝 24 小时跟踪你的行踪2. 关闭相机、麦克风权限小游戏、杂牌软件、工具箱全部禁用相机 + 麦克风防止后台偷偷录音、偷拍3. 关闭自动读取剪贴板杜绝 APP 偷看你复制的密码、验证码、聊天内容隐私再也不被偷偷收集4. 关闭后...

手机与电脑如何传递数据

手机+电脑 极简传文件速查表(直接照做,保存备忘录) 一、通用懒人(所有手机+电脑,小文件) 微信/QQ文件传输助手 1. 手机、电脑登录同一账号 2. 互相发送图片、文档、截图 3. 缺点:视频、图片会压缩,大文件慢 二、有线极速(原图/大视频/无压缩,推荐) 安卓 + 电...

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

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

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

发表评论

访客

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