news 2026/6/15 12:48:52

Kafka 消息不丢失全攻略:从生产到消费的全链路保障

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Kafka 消息不丢失全攻略:从生产到消费的全链路保障

Kafka 消息不丢失全攻略:从生产到消费的全链路保障

引言

Kafka 以其高吞吐和可靠性在分布式消息系统中广泛应用,但很多人以为 Kafka 默认就能“绝对不丢消息”。事实上,Kafka 的设计目标是高性能 + 可配置的可靠性,要做到真正的“不丢失”,需要从 生产者、Broker、消费者 三个环节同时配置与实践。

本文将带你从消息可能丢失的环节 → 核心机制 → 实战配置 → 运维监控 → 场景化实践,全面解析如何确保 Kafka 消息不丢失。


一、消息可能丢失的环节

在 Kafka 的消息链路中,主要有三类风险:

  1. 生产者发送阶段
  • 网络抖动导致发送失败,但生产者未做重试。
  • 消息还在生产者缓冲区,进程崩溃导致未发出。

2.Broker 存储阶段

  • Leader 宕机:消息只写到 Leader,尚未同步到 Follower 时,新的 Leader 没有这条消息。
  • 磁盘损坏:Broker 写入成功但因硬件损坏丢失。

3.消费者消费阶段

  • 启用了自动提交 offset,消费者逻辑还未处理完消息进程就崩溃,导致消息被“跳过”,无法再消费。

结论:要确保消息不丢失,必须三方协同。


二、核心原理:Kafka 的可靠性机制

1. 副本机制 (Replication)

  • 每个分区可配置多个副本(replication.factor >= 3)。
  • Leader 负责读写,Follower 从 Leader 同步。
  • ISR(In-Sync Replica):与 Leader 保持同步的副本集合。消息只有被写入 ISR 才算 committed。
  • Leader 失效时,从 ISR 里选举新 Leader,确保数据可靠。

2. 生产者确认机制 (Acks)

  • acks=0:不等确认,最快,但最不可靠。
  • acks=1:只等 Leader 确认,Follower 未同步可能丢失。
  • acks=all:等待 Leader + ISR 全确认,最安全。

3. min.insync.replicas 参数

  • 限制消息必须写入多少副本才算成功。
  • 建议配置:replication.factor=3,min.insync.replicas=2,acks=all。
  • 若 ISR 不足,写入失败,保证“要么成功,要么报错”,避免
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/14 9:29:02

64、探索 Ubuntu 中的 C/C++ 编程与 Mono 开发

探索 Ubuntu 中的 C/C++ 编程与 Mono 开发 1. C 与 C++ 基础 C 语言在 Linux 内核开发中占据主导地位,这也是 Linux 能够适配多种不同 CPU 的原因。C++ 是 C 语言的面向对象扩展,由于 C++ 是 C 的超集,C++ 编译器可以正确编译 C 程序,并且可以在 C++ 中编写非面向对象的代…

作者头像 李华
网站建设 2026/6/14 13:53:35

OJ刷题小结(12.13~12.14)

题目1:求n个实数去掉最大最小值后的平均值(快乐刷题周末B)问题:思路:找到最大值最小值的下标,将0赋值给该下标对应的数组元素,再遍历数组,将所有元素相加,最后/&#xff…

作者头像 李华
网站建设 2026/6/14 11:36:23

SQLALchemy与fastapi结合的基本流程与注意事项整理

文章目录一、模块导入二、初始化FastAPI对象三、数据库配置1、定义 SQLite 数据库的连接路径2、创建数据库连接3、创建会话四、创建数据库模型1、创建一个基础类2、定义数据库模型五、创建数据库表六、创建用户模型七、设置接口实例一、模块导入 from fastapi import FastAPI,…

作者头像 李华
网站建设 2026/6/14 0:51:45

通达信抄底王 源码

{}VAR2:MA(CLOSE, 5); VAR3:MA(CLOSE, 10); VAR4:MA(CLOSE, 20); VAR5:MA(CLOSE, 30); VAR6:(VAR2VAR3VAR4VAR5)/4; VAR7:(VAR6-REF(VAR6, 15))/REF(VAR6, 15)*100; VAR8:(VAR6-REF(VAR6, 15))/REF(VAR6, 15)*100; VAR9:EMA(VAR7, 8);{} 反转:STICKLINE(VAR9>1*REF(VAR9, 1)…

作者头像 李华