Java消息中间件-Kafka全解(2026精简版)

从概念、安装、配置到高阶玩法与踩坑实录,一份速查表带走

一、概念:10秒建立知识坐标

  • 定位:分布式流式发布/订阅消息系统,高吞吐、可持久化、可水平扩展

  • 核心模型: Topic → Partition → Offset Producer → Broker → Consumer(Group)

  • 四大API:Producer / Consumer / Streams / Connect

二、安装&启动(Linux/Mac 3命令)

1.下载 & 解压

wget https://downloads.apache.org/kafka/3.8.0/kafka_2.13-3.8.0.tgz tar -xzf kafka_2.13-3.8.0.tgz && cd kafka_2.13-3.8.0

2.启动ZK(Kafka7已内置,但生产仍推荐独立ZK)

bin/zookeeper-server-start.sh config/zookeeper.properties

3.启动Broker

bin/kafka-server-start.sh config/server.properties

Windows 用同目录 .bat 即可

三、必改配置清单

示例值

说明

broker.id

0

集群内唯一

listeners

PLAINTEXT://内网IP:9092

监听器,Docker/NAT必须显式

advertised.listeners

PLAINTEXT://外网IP:9092

客户端真正连接的地址

log.dirs

/data/kafka-logs

数据目录,SSD最佳

zookeeper.connect

zk1:2181,zk2:2181

集群地址

num.partitions

12

默认分区数,≤Broker数×2

retention.ms

86400000

消息保留24h

compression.type

lz4

压缩,高吞吐场景利器

端口/地址配错是第一大坑,Docker部署一定保持 listeners 与 advertised.listeners 映射一致 。

四、Spring Boot 3 最小可运行代码

依赖:

<dependency> <groupId>org.springframework.kafka</groupId> <artifactId>spring-kafka</artifactId> </dependency>

yml:

spring: kafka: bootstrap-servers: node1:9092,node2:9092 producer: retries: 3 batch-size: 16384 # 16KB批 linger-ms: 10 acks: all # 高可靠 consumer: group-id: ${spring.application.name} enable-auto-commit: false auto-offset-reset: earliest max-poll-records: 500

生产者:

@RestController class ProducerCtl { @Autowired private KafkaTemplate<String,String> tpl; @GetMapping("/send") public String send(String msg){ tpl.send("demo", msg); return "ok"; } }

消费者(手动提交,幂等):

@KafkaListener(topics = "demo") public void listen(ConsumerRecord<String,String> rec, Acknowledgment ack){ System.out.println("收到 = " + rec.value()); ack.acknowledge(); // 手动提交offset }

启动即跑 。

五、进阶:高吞吐 & 低延迟组合拳

优化点

建议值

说明

batch.size

32KB-128KB

批量发送,提高吞吐

linger.ms

5-20

等待批填满

compression.type

lz4/zstd

压缩比&CPU平衡

acks

1 / all

1=低延迟;all=高可靠

max.poll.records

500-1000

每次拉取条数

分区数

≈ Broker数 × 2

并行度最大

内存映射

给足 OS PageCache

磁盘读↓

只加分区不加 Broker 是第二大坑,CPU/磁盘 IO 会爆 。

六、黑科技玩法

  1. 消息轨迹 → 给每条消息注入 trace-id,利用 Kafka Connect 写入 ES 可视化

  2. 流式 Join → Kafka Streams 双 Topic 按 Key 时间窗口 join,实时拼单

  3. 无限保序 → 单分区 + 幂等 Producer (enable.idempotence=true),Exactly-Once 语义

  4. Retry + DLQ → 消费失败超次后自动写 topic-demo-DLQ,隔离死信

  5. 热扩容 → bin/kafka-reassign-partitions.sh 在线迁移副本,业务无感知

七、易踩坑 & 急救

坑点

现象

急救方案

端口/地址配错

客户端连不上

listeners & advertised.listeners 用外网 IP,Docker 映射一致

消息丢失

生产成功但消费不到

acks=all + 副本因子 ≥ 2 + 手动提交 offset

磁盘爆满

Broker 挂死

定时清理 log.retention.hours / retention.ms

大消息拖慢

TPS 骤降

增大 replica.fetch.max.bytes + 压缩 lz4

只扩分区不扩机器

CPU 飙高

分区数 ≤ Broker×2

GC 风暴

延迟抖动

给足 16G+ 堆,G1GC,-XX:MaxGCPauseMillis=100

八、一条命令巡检集群健康

bin/kafka-run-class.sh kafka.tools.JmxTool \ --object-name kafka.server:type=BrokerTopicMetrics,name=MessagesInPerSec,topic=* \ --jmx-url service:jmx:rmi:///jndi/rmi://localhost:9999/jmxrmi

关注 MessagesInPerSec、RequestQueueTimeMs、ConsumerLag 三个指标,Lag > 5 万就要扩容或加 Consumer 了。

九、一句话总结

Kafka = 分区顺序写 + PageCache 零拷贝 + 批压缩 三驾马车, “地址配好、批要开大、分区与 Broker 同步扩、监控 Lag 及时告警” —— 记住这四句,面试、调优、扛高并发都不会翻车!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1119908.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习率调整与优化技巧相关 TensorFlow安装依赖冲突解决方案汇总

点赞、关注&#xff0c;不迷路 点赞、关注&#xff0c;不迷路 在使用TensorFlow进行深度学习模型开发时&#xff0c;学习率调整与优化是提升模型性能的关键环节&#xff0c;而TensorFlow的安装及依赖配置则是基础前提。实际操作中&#xff0c;常出现因依赖版本不兼容、环境配置…

【课程设计/毕业设计】人工智能基于python深度学习的鲜花识别

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

深度学习计算机毕设之基于python深度学习的鲜花识别

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

学霸同款2026最新!9款AI论文写作软件测评:毕业论文高效写作指南

学霸同款2026最新&#xff01;9款AI论文写作软件测评&#xff1a;毕业论文高效写作指南 2026年AI论文写作工具测评&#xff1a;高效写作从这里开始 随着人工智能技术的不断进步&#xff0c;越来越多的学术工作者开始借助AI工具提升论文写作效率。然而&#xff0c;面对市场上琳琅…

“休眠当关机”,实现不动硬件的一键开关机

方案选择&#xff08;按硬件改动量从小到大&#xff09;方案 A&#xff1a;板上已经有一个按键接到 GPIO&#xff08;最理想&#xff0c;0 改硬件&#xff09;你只要确认这个 GPIO 是 RTC GPIO&#xff08;S3 支持 EXT0/EXT1 唤醒的那类脚&#xff09;&#xff0c;然后固件做&a…

【毕业设计】基于python机器学习的鲜花识别

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

市面上网站建设哪家专业

如何选择专业的网站建设服务商&#xff1f;深度解析与品牌推荐在数字化转型浪潮中&#xff0c;一个专业、高效且具备营销力的企业网站&#xff0c;已成为生产型企业不可或缺的线上门户与增长引擎。然而&#xff0c;面对市场上琳琅满目的建站服务&#xff0c;许多企业主感到困惑…

纯图像传感器(只出像素),还是 Himax WiseEye/WE1/WE-I Plus 这类带处理器、能在端侧跑模型并输出“metadata”的模块

下面这 3 点都能做&#xff0c;但关键在于你说的 “Himax” 是哪一类&#xff1a;纯图像传感器&#xff08;只出像素&#xff09;&#xff0c;还是 Himax WiseEye/WE1/WE-I Plus 这类带处理器、能在端侧跑模型并输出“metadata”的模块。两种方案实现路径不一样。 1&#xff09…

靠谱的网站建设哪家专业

靠谱的网站建设哪家专业&#xff1f;深度解析企业官网建设的核心与选择在数字化转型浪潮席卷各行各业的今天&#xff0c;一个专业、可靠的企业官网已不再是可有可无的“门面”&#xff0c;而是企业获取客户信任、展示核心实力、实现营销增长的战略要地。然而&#xff0c;面对市…

esp32c5跟esp32c6模块可以获取wifi的snr吗?

可以&#xff0c;但要分清两种“获取 SNR”的含义&#xff1a; 1&#xff09;正常 STA 连接状态&#xff1a;基本拿不到“真实 SNR” ESP-IDF 在常规 Wi-Fi 连接&#xff08;STA&#xff09;里常用能拿到的是 RSSI&#xff08;例如 esp_wifi_sta_get_ap_info() 里的 wifi_ap_…

MySQL 工具使用指南

一、mysql bin下的一些可执行文件这些文件是编译后的二进制可执行文件。二、MySQL 各工具的实际类型工具类型说明mysql二进制用 C/C 编写&#xff0c;编译成二进制mysqldump二进制或Perl脚本取决于 MySQL 版本和安装方式mysqladmin二进制用 C/C 编写mysqlcheckPerl 脚本是一个 …

鸿蒙生态再落一子,广汽集团与华为终端达成全面合作

云开发 在鸿蒙操终端设备数量突破3600万台、生态发展进入快车道之际&#xff0c;鸿蒙生态今日再次迎来汽车产业的重量级合作伙伴。1月5日&#xff0c;华为常务董事、产品投资评审委员会主任、终端BG董事长余承东带队访问广汽集团番禺总部&#xff0c;并与广汽集团董事长冯兴亚等…

【2025最新】HCIA-AI V4.0 备考全攻略:从 DeepSeek 到昇腾底层逻辑,全网最细避坑指南

前言&#xff1a;华为认证 HCIA-AI 已经升级到 V4.0 版本。相比 V3.5&#xff0c;新版不仅仅是增加了大模型&#xff08;DeepSeek&#xff09;和 AI4Science&#xff0c;更在 MindSpore 2.0 语法、昇腾计算架构&#xff08;CANN&#xff09;以及模型推理优化&#xff08;MindIE…

AI编程会让程序员集体失业吗?

看到一个很有争议的一个问题&#xff0c;AI Coding已经能编出很完美的程序&#xff0c;程序员这个行业以后是不是会消失&#xff1f;其实vibe coding&#xff08;氛围编程&#xff09;还是个伪命题&#xff0c;更不要说替代程序员了。大家都在说AI已经能写出完美的程序&#xf…

【毕业设计】人工智能基于python深度学习的树叶健康识别

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

告别手动修图!AI指令改图助力电商人,轻松搞定全场景素材需求

电商运营中&#xff0c;视觉素材直接影响转化&#xff0c;但改图痛点突出&#xff1a;与设计师反复沟通、排期等待耗时费力&#xff0c;旺季赶进度更是焦灼。AI指令改图功能完美破解困境&#xff0c;无需懂设计&#xff0c;输入指令即可精准改图&#xff0c;适配全电商场景。下…

【华为认证】HCIP-AI V1.0 深度进阶:人工智能应用的趋势与挑战(高级工程师版)

0. 前言&#xff1a;从“小模型”到“大底座”的范式革命作为 AI 开发者&#xff0c;我们正在经历从 Discriminative AI&#xff08;判别式 AI&#xff09; 到 Generative AI&#xff08;生成式 AI&#xff09; 的范式转移。在 HCIA 阶段&#xff0c;我们关注的是针对特定任务训…

【华为认证】HCIP-AI V1.0 深度进阶:AI 芯片与算力底座——解构达芬奇架构的矩阵暴力

0. 前言&#xff1a;为什么大模型时代“算力”是第一生产力&#xff1f;在 HCIA 阶段&#xff0c;我们习惯于调用 model.train()。但在高级工程领域&#xff0c;你会发现 Memory Wall&#xff08;存储墙&#xff09; 和 Compute Bound&#xff08;计算受限&#xff09; 才是真正…

【课程设计/毕业设计】基于python深度学习的树叶健康识别

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

【华为认证】HCIP-AI V1.0 深度进阶:推理架构与向量数据——构建高效 AI 流水线

0. 前言&#xff1a;为什么高级工程师要将推理与数据解耦再重构&#xff1f;在 HCIA 阶段&#xff0c;我们认为数据处理就是 Pandas 洗洗表&#xff0c;推理就是 model.predict()。但在高并发、大规模的昇腾&#xff08;Ascend&#xff09;生产环境中&#xff1a;推理基础&…