Kafka2.0服务端写入和读取流程
2019-08-16 10:40:08来源:博客园 阅读 ()
Kafka2.0服务端写入和读取流程
写入流程
??Kafka 服务端通过KafkaApis
的handle()
方法来统一处理请求,ApiKeys
枚举了能被handle()
方法处理的请求类型吗,如果是PRODUCE
类型,表示有生产者客户端发送了消息,之后将消息传递给副本管理器处理。
??副本管理器会将消息追加到分区 leader 副本的日志文件中,然而实际上并不是直接写入磁盘的,Kafka 会将日志的段 segment 缓存到跳跃表ConcurrentSkipListMap
。写入日志时,首先会从缓存中查找段,如果能找到,则向该段中追加记录,记录包含日志文件、索引文件、时间戳文件。日志文件会被写入FileChannel
中,索引文件和时间戳文件会被写入MappedByteBuffer
中。最后,后台调度程序会周期地将段文件刷新到磁盘持久化。
??如果段缓存中没有找到合适的段,则通过FileChannel
来打开一个新的段,返回磁盘文件的段映射,封装为 segment 后,再缓存到跳跃表中,供下一次追加日志时使用。
日志的写入处理流程
索引和偏移量的写入处理流程
读取流程
??如果请求是FETCH
类型,表示有消费者客户端发送了拉取请求,同样,将请求传递给副本管理器处理。
??副本管理器在写入日志时,将段缓存到了跳跃表中,因此读取时,可以直接从跳跃表中获取段,向该段发起读取操作。首先,利用二分查找算法,查找mmap
中的索引文件,根据索引文件记录的日志偏移量,遍历查找FileChannel
中的日志文件所在的位置,最后,根据偏移量和需要拉取的大小获取日志片段,返回给消费者。
日志的读取处理流程
原文链接:https://www.cnblogs.com/bigshark/p/11210876.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:字节流与字符流的区别
- 聊聊微服务架构及分布式事务解决方案! 2020-06-10
- java环境教程:Tomcat下载,安装,设置为Windows服务,启动 2020-06-09
- Spring Cloud微服务(一):公共模块的搭建 2020-06-07
- Java生鲜电商平台-微服务生鲜电商系统设计(小程序/APP) 2020-06-04
- 微服务平台技术架构 2020-06-02
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash