Kafka实现高并发的原理(消息中间件如何实现每秒几十万的高并发写入)

本文介绍了Kafka如何利用页缓存技术和磁盘顺序写实现高并发写入,详细阐述了Produce阶段的Page Cache机制以及Consume阶段的零拷贝技术,揭示了Kafka高吞吐性能背后的秘密。同时,文章提及了Kafka性能测试中的磁盘IO指标,如iops和bw,强调了磁盘IO性能对Kafka的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第一部分 原理介绍

Kafka: 是一个高吞吐低延迟的高并发,高性能消息中间件。配置良好的Kafka集群能够做到每秒几十万或者上百万的超高并发写入。

Produce

页缓存技术+磁盘顺序写

Kafka接收到数据的时候,都会往磁盘上去写

在这里插入图片描述

Page Cache

内存里面的缓存,是操作系统自己管理的缓存。

在写入磁盘文件的时候,可以直接写入到OS cache里。接下来由操作系统自己决定何时把cache里面的数据刷写到磁盘文件当中。

在这里插入图片描述
而且kafka写数据的时候,是以磁盘顺序写的方式来写的。

就是说写数据是按照追加文件末尾来写,而不是随机写的。

Consume

消费的本质是从磁盘文件读取某条数据然后发送到下游的消费者。

在这里插入图片描述首先先判断数据是否在os cache,不在的话从磁盘文件中读取,放到cache当中.

然后从操作系统的OS cache里拷贝数据到应用程序进程的缓存去,再从应用程序进程的缓存拷贝数据到操作系统里面的socket缓存里面。

再从socket提取数据发送到网卡。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值