Kafka高性能

页缓存技术 + 磁盘顺序写

页缓存技术 + 磁盘顺序写主要体现在生产者生产数据这块

首先 Kafka 每次接收到数据都会往磁盘上去写,如下图所示:
在这里插入图片描述
为了保证数据写入性能,首先 Kafka 是基于操作系统的页缓存来实现文件写入的。
操作系统本身有一层缓存,叫做 Page Cache,是在内存里的缓存,我们也可以称之为 OS Cache,意思就是操作系统自己管理的缓存。
你在写入磁盘文件的时候,可以直接写入这个 OS Cache 里,也就是仅仅写入内存中,接下来由操作系统自己决定什么时候把 OS Cache 里的数据真的刷入磁盘文件中。可以将磁盘文件写性能提升很多了,因为其实这里相当于是在写内存,不是在写磁盘,大家看下图:
在这里插入图片描述
另外一个就是 kafka 写数据的时候,非常关键的一点,它是以磁盘顺序写的方式来写的。仅仅将数据追加到文件的末尾,不是在文件的随机位置来修改数据。
普通的机械磁盘如果你要是随机写的话,确实性能极差,也就是随便找到文件的某个位置来写数据。
但是如果你是追加文件末尾按照顺序的方式来写数据的话,那么这种磁盘顺序写的性能基本上可以跟写内存的性能本身也是差不多的。

零拷贝技术

零拷贝技术体现在消费者消费数据这块
从 Kafka 里我们经常要消费数据,那么消费的时候实际上就是要从 Kafka 的磁盘文件里读取某条数据然后发送给下游的消费者,如下图所示:
在这里插入图片描述
假设要是 Kafka 什么优化都不做,就是很简单的从磁盘读数据发送给下游的消费者,那么大概过程如下所示:

  • 先看看要读的数据在不在 OS Cache 里,如果不在的话就从磁盘文件里读取数据后放入 OS Cache。

  • 接着从操作系统的 OS Cache 里拷贝数据到应用程序进程的缓存里,再从应用程序进程的缓存里拷贝数据到操作系统层面的 Socket 缓存里。

  • 最后从 Socket 缓存里提取数据后发送到网卡,最后发送出去给下游消费。
    在这里插入图片描述
    可以看到有两次没必要的拷贝吧!一次是从操作系统的 Cache 里拷贝到应用进程的缓存里,接着又从应用程序缓存里拷贝回操作系统的 Socket 缓存里。为了进行这两次拷贝,中间还发生了好几次上下文切换,一会儿是应用程序在执行,一会儿上下文切换到操作系统来执行。Kafka 为了解决这个问题,在读数据的时候是引入零拷贝技术。
    直接让操作系统的 Cache 中的数据发送到网卡后传输给下游的消费者,中间跳过了两次拷贝数据的步骤,Socket 缓存中仅仅会拷贝一个描述符过去,不会拷贝数据到 Socket 缓存。

在这里插入图片描述
通过零拷贝技术,就不需要把 OS Cache 里的数据拷贝到应用缓存,再从应用缓存拷贝到 Socket 缓存了,两次拷贝都省略了,所以叫做零拷贝。对 Socket 缓存仅仅就是拷贝数据的描述符过去,然后数据就直接从 OS Cache 中发送到网卡上去了,这个过程大大的提升了数据消费时读取文件数据的性能。

而且大家会注意到,在从磁盘读数据的时候,会先看看 OS Cache 内存中是否有,如果有的话,其实读数据都是直接读内存的。
如果 Kafka 集群经过良好的调优,大家会发现大量的数据都是直接写入 OS Cache 中,然后读数据的时候也是从 OS Cache 中读。
相当于是 Kafka 完全基于内存提供数据的写和读了,所以这个整体性能会极其的高。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为了实现高性能Kafka从以下几个方面进行了优化: 1. 批处理:Kafka通过批量处理消息来提高性能。生产者可以将多个消息一起发送到Kafka代理,而不是单独发送每个消息。消费者也可以一次拉取多个消息,而不是单独拉取每个消息。这种批处理方式可以减少网络开销和磁盘IO,从而提高性能。 2. 零拷贝:Kafka使用零拷贝技术来避免数据在内存和磁盘之间的复制。当消息从生产者发送到Kafka代理时,Kafka可以直接将消息从内存复制到网络套接字缓冲区中,而不需要将消息从内存复制到用户空间缓冲区,再从用户空间缓冲区复制到内核空间缓冲区,最后再从内核空间缓冲区复制到网络套接字缓冲区。这种零拷贝方式可以减少CPU和内存的开销,从而提高性能。 3. 分区和副本:Kafka将每个主题分成多个分区,并将每个分区的数据复制到多个副本中。这种分区和副本的方式可以提高并发性和可靠性。生产者可以将消息发送到不同的分区,消费者可以从不同的副本读取消息,从而提高并发性。如果某个副本失效,Kafka可以从其他副本中恢复数据,从而提高可靠性。 4. 高效压缩:Kafka支持多种压缩算法,包括Gzip、Snappy和LZ4。这些压缩算法可以在减少网络传输数据的同时,保证数据的可靠性和完整性。 下面是一个使用Kafka Python客户端库kafka-python发送和接收消息的例子: ```python from kafka import KafkaProducer, KafkaConsumer # 生产者发送消息 producer = KafkaProducer(bootstrap_servers=['localhost:9092']) producer.send('test', b'hello world') # 消费者接收消息 consumer = KafkaConsumer('test', bootstrap_servers=['localhost:9092']) for message in consumer: print(message.value) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值