当前位置: 首页 > news >正文

图解Kafka高性能之谜(五)

  • 高性能的多分区、冗余副本集群架构

  • 高性能网络模型NIO

        简单架构设计:

详细架构设计:

  • 高性能的磁盘写技术

  • 高性能的消息查找设计

        索引文件定位使用跳表的设计

        偏移量定位消息时使用稀疏索引:

  • 高响应的磁盘拷贝技术

kafka采用sendFile()的零拷贝方式,磁盘DMA到内存,然后一次cpu copy到socket缓存,一次DMA到网卡完成数据发送。

  • 粘性分区算法

如下图,6条消息采用key可能分三次发送到三个不同的分区,需要3次网络请求。如果没有key将封住成一个批次发送。这样一次网路请求就可以发送多条消息,大大提高了效率。

  • 批处理、内存池设计

将多个同分区的消息,一次批量发送到server,大大减少了网络IO的消耗。

BufferPool 总大小为16k固定大小加上一个avaliableMemory(存储大消息),每个batch申请内存释放内存,循环往复。

  • 多线程协同设计

图是发送消息主线程和发送网络请求sender线程配合获取元数据的流程:

  • 高性能、安全的数据结构

RecordAccumulator中存储了每个分区对应的消息队列,在发送消息时会经常读取队列将消息加入到队列中。所以在batches设计时需要考虑到高性能、高并发的。

private final ConcurrentMap<TopicPartition, Deque<ProducerBatch>> batches;

  • 分段锁的设计思想

  • 粘包黏包解决

读取数据时kafka采用了4字节标识数据长度来避免粘包黏包的问题:

http://www.lryc.cn/news/214755.html

相关文章:

  • opencv在linux上调用usb摄像头进行拍照
  • 软考之知识产品+例题
  • 玩了一下 Jenkins,最新版本 + JDK11
  • 自定义的卷积神经网络模型CNN,对图片进行分类并使用图片进行测试模型-适合入门,从模型到训练再到测试,开源项目
  • C# 使用.NET的SocketAsyncEventArgs实现高效能多并发TCPSocket通信
  • 设计模式——观察者模式(Observer Pattern)+ Spring相关源码
  • openpnp - code review - 开机对话框历史记录和贡献者名单
  • JavaSE22——HashMap
  • 「图像 merge」无中生有制造数据
  • RK3588之ArmSoM-W3 + MPP实现多路硬解码拉流
  • 【Rust日报】2023-10-29 隆重推出 Rerun 0.10!
  • AI智能识别如何助力PDF,轻松实现文档处理?
  • 【SA8295P 源码分析】114 - 将Android GVM userdata文件系统从 EXT4 修改为 F2FS
  • LeetCode 387 字符串中的第一个唯一字符 简单
  • 线程池--简单版本和复杂版本
  • docker进阶
  • Unity HoloLens 2 应用程序发布
  • 3D RPG Course | Core 学习日记三:Navigation智能导航地图烘焙
  • Linux 启用本地ISO作为软件源
  • SpringCloud-Alibaba-Nacos2.0.4
  • docker运行镜像相关配置文件
  • 引擎系统设计思路 - 用户态与系统态隔离
  • 致远OA wpsAssistServlet任意文件读取漏洞复现 [附POC]
  • ​轻量应用服务器有什么优势?如何评价亚马逊云科技轻量应用服务器?
  • python的日志模块学习记录
  • 【java】redisTemplate mock时报空指针
  • Hadoop PseudoDistributed Mode 伪分布式
  • 个人职业规划
  • Linux | 如何保持 SSH 会话处于活动状态
  • 树结构及其算法-二叉树节点的插入