Kafka高级
- 目录
- 概述
- 需求:
- 设计思路
- 实现思路分析
- Kafka高级_工作流程
- Kafka高级_文件存储
- 参考资料和推荐阅读
Survive by day and develop by night.
talk for import biz , show your perfect code,full busy,skip hardness,make a better result,wait for change,challenge Survive.
happy for hardess to solve denpendies.
目录
概述
需求:
设计思路
实现思路分析
Kafka高级_工作流程
Kafka的工作流程如下:
-
Producer:消息生产者将消息发送到Kafka集群。Producer可以将消息发送到指定的Topic,也可以将消息发送到多个Topic。Producer也可以指定消息的分区方式和消息的顺序。
-
Broker:Kafka集群由多个Broker组成,每个Broker是一个独立的Kafka服务器。每个Broker负责管理一部分Topic的分区副本。Broker接收来自Producer的消息,并将其存储在磁盘上,以便后续的消费者能够消费。
-
Topic:Topic是Kafka中的消息存储单元,消息按Topic进行分类。Topic可以分为多个分区,并且每个分区可以有多个副本。分区的主副本负责处理消息的读写请求,其他副本用于备份和容错。
-
Partition:每个Topic可以分为多个分区,分区是Kafka中的消息存储和处理的最小单元。每个分区都有一个唯一的标识符和一个副本集,副本集中的一个副本被指定为分区的主副本,其他副本是从副本。
-
Consumer:消息消费者从Kafka集群中读取消息。消费者可以订阅一个或多个Topic,并根据自己的需求读取消息。消费者可以以不同的方式读取消息,如批量读取、按时间戳读取等。
-
Consumer Group:多个消费者可以组成一个消费者组,消费者组可以并行地消费一个或多个Topic的消息。每个分区只能由一个消费者组中的一个消费者来消费。消费者组可以实现消息的并行消费和负载均衡。
-
Offset:每个分区都有一个唯一的偏移量,用于标识分区中消息的位置。消费者可以保存当前消费的偏移量,并在下次启动时从该偏移量继续消费。Kafka还会定期清理过期的偏移量。
-
ZooKeeper:ZooKeeper是Kafka必需的分布式协调服务。ZooKeeper负责管理和协调Kafka集群的Broker、Topic、分区等元数据。Kafka通过与ZooKeeper进行交互,实现集群的管理和故障恢复。
Kafka高级_文件存储
Kafka中的文件存储是指Kafka使用文件系统来存储消息数据。
Kafka通过分区来组织消息的存储,每个分区都会对应一个或多个文件,这些文件被称为日志片段(Log Segment)。每个日志片段都是一个文件,存储了一定时间范围内的消息数据。
Kafka的文件存储采用顺序写入的方式进行,即每个分区的消息数据按照顺序追加到日志片段中。这种方式有助于提高写入性能,并且也减少了磁盘的随机访问。
当一个日志片段已经达到一定的大小(通过配置参数设置),Kafka会自动对其进行切分,生成新的日志片段。这样可以保证每个日志片段的大小都是可控的,并且可以方便地根据时间来删除过期的消息数据。
Kafka的文件存储具有高吞吐量、高持久性、高可靠性的特点。它可以支持大规模的消息存储和访问,并且具有良好的水平扩展性。同时,Kafka还提供了一些高级的功能,例如消息压缩、消息索引、消息删除等,来进一步提升性能和灵活性。
总之,Kafka的文件存储是一种高效、可靠的消息存储方式,适用于各种场景的大规模数据处理和分发。
参考资料和推荐阅读
参考资料
官方文档
开源社区
博客文章
书籍推荐
- https://www.bilibili.com/video/BV1a4411B7V9?p=11
欢迎阅读,各位老铁,如果对你有帮助,点个赞加个关注呗!同时,期望各位大佬的批评指正~,如果有兴趣,可以加文末的交流群,大家一起进步哈
-
猜你喜欢
网友评论
- 搜索
- 最新文章
- 热门文章