速来报名!AICon北京站鸿蒙专场~ 了解详情
写点什么

系统解读 Kafka 的流和表(一):开篇

  • 2020-02-07
  • 本文字数:2270 字

    阅读完需:约 7 分钟

系统解读Kafka的流和表(一):开篇

这是探索 Kafka 存储层和处理层核心基础系列文章的第一篇。在这篇文章中,我们将总体介绍事件、流、表以及流和表之间的二元性关系。后续的文章将着重探索 Kafka 的存储层,也就是流和表的分布式“文件系统”,然后再介绍位于存储层之上的处理层。


我与很多 Kafka 用户有过交流,他们当中有开发人员、运维人员和架构师,有一些有流式处理或 Kafka 使用经验,有一些精通关系型数据库(如 Oracle 和 MySQL),有一些则两者都不熟悉。不过,他们会问我相同的问题,比如:“事件流和数据库表之间有什么区别?Kafka 的主题跟流是同一种东西吗?如果把数据放在 Kafka 里,如何最大程度地利用它们?”

事件、流、表

我们先从最基本的开始:Kafka 是什么?Kafka 是一个事件流平台,它提供了这三个关键特性:


  1. 发布和订阅事件;

  2. 按需存储事件;

  3. 处理和分析事件。


那么这里所说的事件是什么东西?


事件记录了真实世界“发生了某件事情”。从概念上讲,一个事件包含一个键、一个值和时间戳。事件可以是一个普通的通知,可能不包含额外的信息,也可能包含所有可用于后续处理的细节。例如:


  • 键:“Alice”;

  • 值:“Is currently in Rome”;

  • 时间戳:“Dec. 3, 2019 at 9:06 a.m.”。


事件还可能是这样的:


  • 卖出一件商品;

  • 数据库表的一条记录被更新;

  • 风机传感器测量到叶片每分钟转 14 次;

  • 下棋时发生的一个动作,比如“白方将 e2 位置上的小兵移到 e4 上”;

  • Frank 在 2019 年 11 月 24 晚上 5 点 11 分向 Sally 支付了 200 美元。


事件流平台捕捉事件,将事件形成事件流。事件流按照事件的顺序记录了真实世界发生的历史,例如销售账簿或者象棋比赛时记录的棋子移动顺序。Kafka 的流可以记录几百年的业务历史事件。它们是按顺序排列的事件链,我们可以知道哪个事件是在哪个事件之前或之后发生的。所以,流代表了过去和现在:当时间从今天走向明天,或者从这一毫秒走到下一毫秒,新的事件会持续不断地被追加到历史中。


与事件流不一样,数据库的表代表的是世界在某个时间点的状态,通常是“现在”。例如,商品的总销量或者象棋比赛中棋盘的当前布局。表是事件流的一个视图,在捕捉到新事件时就会更新这个视图。



流记录了历史,表代表的是状态


在 Kafka 里,流和表有很多不一样的地方,其中最突出的一点是它们的内容是否可变(我所说的表是指 Kafka Streams 里的 KTable)。


  • 流提供的是不可变数据。它只支持插入(追加)新的事件,已有的事件不能被修改。流中的数据是持久化的,支持容错。流中的事件包含了键,一个键可以对应多个事件,比如“与 Bob 相关的所有支付事件”。不严格地说,你可以把流看成是关系型数据库里的一张表,只是它没有唯一键约束,而且只能追加记录。

  • 表提供的是可变数据。你可以插入新数据,已有的数据可以被更新或删除。事件的键(也就是数据行的标识)是可变的。与流一样,表也是持久化的,支持容错。现在的表就像是关系型数据库里的物化视图,当输入流发生变化时,它会自动更新,不会让你直接对它执行插入、更新或删除操作。


流和表的二元性

虽然流和表之间有所区别,但也存在非常紧密的联系。我们把它们之间的这种关系叫作流和表的二元性:


  • 我们可以通过一些聚合操作,比如 COUNT()或者 SUM(),将流转成表。在象棋比赛中,我们可以通过重放所有已记录的棋子移动事件来重建棋局的最新状态(也就是表)。

  • 我们也可以通过捕获表的变更事件(插入、更新、删除),把事件汇聚成“变更流”,这样就可以将表转成流。这个过程一般被称为变更数据捕获,简称 CDC(Change Data Capture)。在象棋比赛中,我们可以观察最新的棋子移动,并把它记录下来(加入到流中)。或者,我们也可以比较棋局状态前后的变化,将发生变化的部分记录下来,只是这种方式比前面那种要慢一些。


实际上,表的底层就是变更流。如果你有使用过 Oracle 或 MySQL,就应该知道,这些关系型数据库也存在变更流,只是实现细节被隐藏起来了,它们的名字叫重做日志(redo log)或二进制日志(binary log)。在事件流中,重做日志是一等实体,也就是流。我们可以将流转成表,也可以将表转成流。



因为流和表的二元性,我们可以很容易地将流转成表,或者反过来。


下面的例子使用 COUNT()将流聚合成一个表。为了方便展示,图中没有显示时间戳。随着新的事件不断被加入流中,表被持续更新,与关系型数据库的物化视图类似,只是它每秒钟可以支持数百万个事件。我们可以把这个想象成是对一个表进行 CDC,然后生成一个输出变更流。对一个事件流进行聚合操作则是反过来的:流成了表的输入变更流。


在这个例子中,事件流中事件的键为用户名,值为用户所在位置,事件被持续地聚合成表,并根据键来跟踪用户访问过的位置次数。



将事件流聚合成表


下面是这个例子对应的代码:



我们也可以看到表的输出变更流。变更流对表的变更做出实时响应,以此来生成警报。它也可以被用在运维中,比如将一个表从机器 A 迁移到机器 B 上。



每张表都自己的变更流(也叫变更日志)


在后续的文章中,我们将会继续讨论流和表的二元性,它是 Kafka 弹性伸缩和容错能力的基础!

总结

在这篇文章中,我们了解了事件流平台的基本元素:事件、流和表。我们还介绍了流和表的二元性,以及为什么说二元性是事件流平台(如 Kafka)的核心。当然,这篇文章只是一个开始,在下一篇文章中,我们将深入了解 Kafka 的主题、分区和存储。


原文链接:


https://www.confluent.io/blog/kafka-streams-tables-part-1-event-streaming/


2020-02-07 12:012983
用户头像
蔡芳芳 InfoQ主编

发布了 801 篇内容, 共 556.9 次阅读, 收获喜欢 2790 次。

关注

评论 2 条评论

发布
用户头像
原文的GIF,译文只有静态的图片
2021-10-24 01:02
回复
用户头像
good

2020-06-10 15:30
回复
没有更多了
发现更多内容

淘宝关键词搜罗神器:深入探索淘宝商品搜索API接口

代码忍者

API 接口 pinduoduo API

实时多模态 AI 的 N 种新可能丨实时互动和大模型专场@RTE2024回顾

声网

AE 3D粒子系统插件:Trapcode Particular for Mac 激活版

你的猪会飞吗

mac软件下载 Mac破解软件

淘宝京东商品详情页接口

tbapi

淘宝API接口 京东API接口 淘宝商品详情接口 京东商品详情接口

快递鸟电子面单批量打印API接口Demo免费下载

快递鸟

快递物流 电子面单

前端页面测试如何定位漏测代码

Hi-CodeCaptain

软件质量 测试覆盖率 精准测试 前端代码 前端覆盖率

淘宝店铺商品全览:揭秘淘宝店铺所有商品API接口的无限商机

代码忍者

API 接口 pinduoduo API

DApp、链游与交易所的盈利点解析:如何在区块链生态中挖掘财富?

区块链软件开发推广运营

交易所开发 dapp开发 链游开发 公链开发 代币开发

BTC矿工转向AI数据:普通人如何低成本布局AI赛道

区块链软件开发推广运营

交易所开发 dapp开发 链游开发 NFT开发 公链开发

After Effects 2022 for Mac(AE 2022)中文版

Mac相关知识分享

【论文速读】| RobustKV:通过键值对驱逐防御大语言模型免受越狱攻击

云起无垠

“融为本,数为源,智为力”开启财务数智化转型华章

用友智能财务

财务 企业数智化 企业数智化转型

BetterDisplay Pro Mac(显示器管理工具) v2.0.11激活版

小玖_苹果Mac软件

使用 NGINX 和 NGINX Plus 实现负载均衡(第 2 部分)

NGINX开源社区

负载均衡 读书笔记

SD-WAN如何解决企业跨国组网难题

Ogcloud

SD-WAN SD-WAN组网 SD-WAN服务商 跨国组网 SD-WAN国际专线

Redis性能优化的18招

不在线第一只蜗牛

redis

茶思屋直播|构建多元共生的生态空间:TinyEngine生态的融合之道

OpenTiny社区

开源 前端 低代码 OpenTiny

Twitterrific for Mac(Twitter客户端)适配Monterey 12

Mac相关知识分享

SpringBoot+Docker +Nginx 部署前后端项目

EquatorCoco

nginx Docker Spring Boot

一文搞懂自动化测试框架设计

快乐非自愿限量之名

自动化 测试

Movist for Mac(强大稳定的视频播放器)

Mac相关知识分享

开源可视化工具对比:JimuReport VS DataEase

JEECG低代码

数据可视化 报表 数据大屏 报表工具 仪表盘设计器

Navicat Premium 15 for Mac(数据库开发工具) v15.0.36中文激活版

小玖_苹果Mac软件

制造业生产遇到“瓶颈”,MES系统帮您重新赋能!

积木链小链

制造业 mes

枫清科技亮相 2024 中国 5G+工业互联网大会,推动 AI 赋能新型工业化

Fabarta

智能体 大模型

《Django 5 By Example》阅读笔记:p679-p765

codists

Python django

我用豆包MarsCode IDE 做了一个 CSS 权重小组件

豆包MarsCode

CSS 程序员 AI

DriveDx for mac(mac磁盘健康检测和监控工具) v1.12.1激活版

小玖_苹果Mac软件

Java哪个框架适合开发API接口?

科普小能手

API java框架 Java 开发 API 接口 Java.

Redis中常见的数据类型及其应用场景

EquatorCoco

数据库 redis

强到连何同学都抄袭的ASCII-generator是什么鬼

安全乐谷

Python OpenCV 开源、 image-to-text image-to-image

系统解读Kafka的流和表(一):开篇_语言 & 开发_Michael Noll_InfoQ精选文章