初识kafka

Kafka目前被定位为一个分布式流式处理平台,它以高吞吐、可持久化、可水平扩展、支持流数据处理等多种特性而被广泛使用。其在应用中主要扮演以下三大角色:

  • 消息系统: Kafka具备系统解耦、冗余在储、流量削峰、缓冲、异步通信、扩展性、可恢复性、消息顺序性保障及消息回溯的功能。
  • 存储系统:Kafka把消息持久化到磁盘,相比于基于内存存储的系统而言,有效
    地降低了数据丢失的风险。
  • 流式处理平台:Kafka不仅为流式处理框架提供了可靠的数据来源,还提供了一个完整的流式处理类库,比如窗口、连接、变换和聚合等各类操作。

1. 体系架构

kafka体系结构

整个体系结构主要包括以下三部分:

  • producer:生产者,负责将消息投递到kafka中。
  • consumer:消费者,通过拉的方式获取消息进行业务处理。
  • broker:一个独立的Kafka服务节点或服务实例,多个broker组成kafka集群。

Kafka通过ZooKeeper来进行元数据管理,包括:集群、broker、主题和分区等。
大概的流程就是:生产者将消息发送给broker,broker将消息存储到磁盘中,消费者从broker拉取并消费消息。

2. 主题和分区

主题(topic)和分区(partition)都是逻辑上的概念。一个主题可以包含多个分区,一个分区只能属于一个主题。
Kafka的消息是按照主题进行分类的,生产者将消息发送给指定的主题,消费者从指定的主题订阅和消费消息。
分区在存储层面来看其实是一个日志文件,如图所示。

分区结构
消息不停的追加到日志文件的尾部,消息在写入分区的时候会被分配一个偏移量(offset),这类似于数组中的下标。offset是消息在分区中的唯一标识,kafka通过它来保证分区内消息的顺序。由于offset只是作用于单partition内部,因为kafka只能保证分区内消息有序,而无法保证主题内有序。另外,主题下的多个分区可以部署在多个broker上,提供比单个broker更强大的性能。
消息在发送到broker之前,会根据分区规则决定发往哪个分区。
分区规则如下:
如果消息中指定了key:分区器会对key进行哈希,最终根据哈希值计算分区号。如果未指定key:则以轮询的方式发送到各个可用的分区。
为什么要有多个分区呢?
刚有提到,分区在存储层面其实是一个日志文件。试想一下,如果一个主题只有一个分区,那么这个文件的所在broker的I/O将会成为这个主题的性能瓶颈,而多分区则解决了这个问题。而且通过增加分区数量可实现水平扩展。

3. 分区可靠性保证

前面说到消息是存储在分区中,而分区分布于不同的broker中,那么broker宕机会导致该机器上的分区不可用,kafka是如何保证可用性的呢?下面就要说下Kafka的多副本(replica)机制,Kafka通过增加副本数量提升容灾能力。

  • 同一分区的不同副本中保存的是相同的消息(在同一时刻,副本之间并非完全一样)。
  • 副本之间是一主多从”的关系,其中leader 副本负责处理读写请求,follower 副本只负责与 leader 副本的消息同步。
  • 副本处于不同的broker中,每个broker最终拥有同一分区的一个副本。当 leader 副本出现故障时,从follower 副本中重新选举新的leader 副本对外提供服务。

Katka 通过多副本机制实现了故障的自动转移,当Kafka 集群中某个broker 失效时仍然能保证服务可用。如图所示,broker数量为4,副本因子为3。


image.png

消费者端也具备一定的容灾能力,消费者会提交自己消费的位置到kafka,当故障恢复后,可以从上次提交的消费位置开始消费。

关于分区的几个概念

  • AR (Assigned Replicas):分区中的所有副本。
  • ISR (In-Sync Replicas):所有与 leader 副本保持一定程度同步的副本(包括 leader 副本在内)组成,ISR 集合是 AR 集合中的一个子集。前面所说的“一定程度的同步” 是指可忍受的滞后范围,这个范围可以通过参数进行配置。
  • OSR (Outof-Sync Replicas):与leader 副本同步滞后过多的副本(不包括leader副本)组成。AR=ISR+OSR。

在正常情况下,所有的follower 副本都应该与 leader 副本保持一定程度的同步,即 AR=ISR,OSR 集合为空。leader副本负责维护和跟踪ISR集合中所有follawer副本的滞后状态,当 follower 副本落后大多或失效时,leader副本会把它从ISR 集合中剔除。如果 OSR 集合中有follover 副本“追上”leader 副本,那么leader副本会把它从 OSR 集合转移至 ISR 集合。默认情况下,当 leader 副发生故障时,只有在 ISR 集合中的副本才有资格被选举为新的leader,而在 OSR 集合中的副没有任何机会(不过这个原则也可以通过修改相应的参数配置来改变)。

  • HW 是 Figh Watermark 的缩写,俗称高水位,它标识了一个特定的消息偏移量 (oftset),消费者只能拉取到这个 ofset 之前的消息。
  • LEO 是 Log End Offset 的缩写,它标识当前日志文件中下一条待写入消息的 offset,LEO 的大小相当于当前日志分区中最后一条消息的 ofset 值加 1。分区 ISR 集合中的每个副本都会维护自身的LEO,而 ISR 集合中最小的 LEO即为分区的 HW,对消费者而言只能消费 HW 之前的消息。举例如下:


    image.png

    假设ISR中有3个副本,1个leader和2个follower,此时分区的HW和LEO都是3。此时生产者发送了消息3和4,优先写入leader副本。由于不同follower副本同步效率不同,此时follower1已同步到了消息3和4,LEO是5;而follower2只同步了消息3,LEO是4,所以整个分区的HW取所有副本最小的LEO=4,因此此时消费者只能消费到4之前的消息,即0、1、2和3。

结束语

本篇主要介绍了Kafka的中一些而基本概念,对其实现没有做深究,主要还是根据书中的顺序来写,没怎么加自己的理解。后面会尝试从《一条消息的一生》这个角度来总结消息生产和消费的过程,以及其中的可靠性是如何保证的。

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

推荐阅读更多精彩内容

  • Kafka介绍 Kafka是LinkedIn采用scala开发的一个多分区, 多副本并且基于ZooKeeper协调...
    xiaogp阅读 175评论 0 1
  • [TOC]Kafka起初是由 Linkedin公司采用 Scala语言开发的一个多分区、多副本且基于 ZooKee...
    tracy_668阅读 465评论 0 7
  • 阅读以下内容你将了解到:1.什么是Kafka2.为什么要使用 Kafka,为什么要使用消息队列3.Kafka中的基...
    就这些吗阅读 288评论 0 0
  • Kafka是由scala和java编写的一款高吞吐量分布式发布订阅消息系统。 应用场景: 异步处理 应用解耦 流量...
    谭英智阅读 292评论 0 1
  • 消息引擎系统 需要考虑的两个重要因素: 消息设计 传输协议设计 消息设计 一天消息要有能够完整清晰表达业务的能力。...
    一笑奈何_abe4阅读 501评论 0 0