kafka学习

带着问题去学习

  1. zk在kafka中扮演什么作用?
  • 保存元数据,比如broker信息,分区信息,消费者的偏移量
  • leader选举
  • 集群监控,比如集群节点的健康检查
  1. kafka中leader挂掉,其他的follower是如何成为leader的?

  2. kafka中的消息传递语义

  • At most once - 消息可能丢失,但是不会重复发送
  • At least once - 消息不可能丢失,但是会重复
  • Exactly once - 每个消息仅仅传递一次
  1. 幂等性生产者
    Kafka 的幂等性生产者是为了确保相同的消息在同一个分区上只被写入一次而设计的。这样可以防止生产者在发送消息时因为一些网络问题或者其他错误导致消息的重复写入。幂等性生产者引入了一些机制来保证这一点:
  • Producer Id(生产者ID): 每个生产者实例都会被分配一个唯一的 Producer Id(PID)。这个 ID 在生产者的整个生命周期内是固定的,它用于标识消息是由哪个生产者发送的。Producer Id 会与一个 epoch(时期)结合,以确保即使生产者发生重新启动,也能够继续使用相同的 Producer Id。

  • Sequence Number(序列号): 每个消息都有一个单调递增的序列号,它是由生产者维护的。序列号的目的是为了确保消息的顺序和一致性。Kafka 使用 Producer Id 和 Sequence Number 来唯一标识一个消息。

  • Broker 端幂等性处理: Kafka 的 broker 端会检测到来自生产者的重复消息,并根据 Producer Id 和 Sequence Number 进行过滤。如果 broker 收到的消息具有相同的 Producer Id 和较小或相同的 Sequence Number,则它会认为这是一条重复消息,并将其过滤掉。

  • Acknowledge(应答机制): 幂等性生产者使用 ACK(应答机制)来确认消息是否成功写入到分区。如果消息在写入后收到了分区的 ACK,那么生产者会认为消息已经成功写入,否则会重试。这确保了消息的可靠性。

通过这些机制,Kafka 的幂等性生产者可以在面临网络故障、生产者重启等情况下,确保相同的消息不会被重复写入到同一个分区。这对于保证消息的一次性投递非常重要,特别是在涉及到事务性和精确一次性语义的场景中。

  1. kafka会不会丢失消息
    会丢失,broker、producer、consumer都可能会丢失消息
    https://zhuanlan.zhihu.com/p/307480336
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,294评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,493评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,790评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,595评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,718评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,906评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,053评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,797评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,250评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,570评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,711评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,388评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,018评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,796评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,023评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,461评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,595评论 2 350

推荐阅读更多精彩内容

  • Kafka 官网: Kafka 主要设计目标如下: 以时间复杂度为 O(1) 的方式提供消息持久化能力,即使对 T...
    灯火gg阅读 747评论 0 2
  • kafka客户端 Kafka除了提供内置Java客户端外,还提供了二进制连接协议,即向Kafka网络端口发送适当的...
    零度沸腾_yjz阅读 2,801评论 0 4
  • 项目4月份发版,直接需要整合kafka,今天开始学,一个月内完成kafka的部分。 资料来源:http://www...
    MisterCH阅读 1,735评论 0 4
  • 生产者就是负责向kafka发送消息的应用程序 客户端开发 一个正常的生成逻辑需要具备一下几个步骤 (1) 配置生产...
    xiaogp阅读 465评论 0 0
  • MQ入门总结(六)Kafka的原理和使用 Kafka的架构原理,你真的理解吗? 真的,Kafka 入门一篇文章就够...
    John13阅读 203评论 0 0