kafka不支持读写分离原理分析

 更新时间:2023年11月07日 10:08:06   作者:cartoon  
这篇文章主要为大家介绍了kafka不支持读写分离原理分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

引言

前段时间在看 kafka 相关内容,发现 kafka “所有的”读写流量都在主 partition 上,从 partition 只负责备份数据。

那么为什么 kafka 从 partition 不跟其他中间件一样承接读流量?

读写分离的初衷

读写分离的初衷我觉得是利用读流量 & 写流量不同的特性做针对性的优化,而这两种流量我觉得区别如下

读流量写流量
业务特性展示类的业务操作类业务
流量占比
可接受数据延迟较大非常小
增长的可预见性高峰/安全攻击可能会突发增长总体平稳

使用 kafka 的业务特征

  • 操作型业务,consumer 消费 producer 生产的消息,进行自身业务,这个消息就类似于 trigger
  • 可支撑的流量较大,并且可支撑下游 consumer 较多,rebalance 需要一定的时间

kafka 架构

  • 以 topic 为单位,一 topic 可拆分多个 partition,每个 partition 都可以有多个从 partition,不同 partition 分布在不同 broker 上
  • 以 partition 为单位,形成 AR(Assigned Repllicas),ISR(In Sync Repllicas),OSR(Out Sync Repllicas),主 partition 接收到消息后按照 ack 策略同步到 ISR 中从 partition

    ack = 0,producer 发出消息后就不管了

    ack = 1,producer 发出消息写入主 partition 所在 broker 的磁盘就算成功

    ack = all,producer 发出消息写入主 partition 以及 ISR 上所有副 partition 的磁盘才算成功

kafka 没有主从读写分离的原因

  • 不能主从读写分离的原因

    kafka 承接的大多是操作型业务,这部分读操作对数据延迟非常敏感。

    kafka 主从同步为半同步复制,并且有部分 partition 在 OSR 上,数据延迟较大

    kafka 主 partition 接收到消息后,可以根据 ack 策略落盘,如果不是 all 的话存在数据丢失的风险

  • 不需要主从读写分离的原因

    kafka 本身就是多 partition 的架构,不同 parition 在不同的 broker 上,多主节点的结构本身分流了流量

    kafka 本身就有成熟的 rebalance 机制,partition 上线与下线都比较无感

以上就是kafka不支持读写分离原理分析的详细内容,更多关于kafka不支持读写分离的资料请关注脚本之家其它相关文章!

相关文章

  • archlinux 罗技K380 F1-F12 功能键锁定(实现方法)

    archlinux 罗技K380 F1-F12 功能键锁定(实现方法)

    这篇文章主要介绍了archlinux 罗技K380 F1-F12 功能键锁定,在windows中罗技K380可以安装Logitech Options来实现这个Fn锁定功能,需要的朋友可以参考下
    2023-04-04
  • HTTP请求首部字段及响应首部字段详解

    HTTP请求首部字段及响应首部字段详解

    这篇文章主要介绍了HTTP请求首部字段及响应首部字段,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-06-06
  • Git基本概述

    Git基本概述

    本文主要介绍了Git的基础知识。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • git中commit和push的区别及说明

    git中commit和push的区别及说明

    这篇文章主要介绍了git中commit和push的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • 一不小心git rebase后出现(master|REBASE 1/10)的问题及解决办法

    一不小心git rebase后出现(master|REBASE 1/10)的问题及解决办法

    这篇文章主要介绍了一不小心git rebase后出现(master|REBASE 1/10)的问题及解决办法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • git回退并提交部分修改文件方式

    git回退并提交部分修改文件方式

    本文介绍了如何使用Git进行版本回退和代码提交,首先,通过回退到指定commit,保留工作区代码,接着,使用git status查看仓库状态,将修改的文件通过git add添加到缓存区,最后,提交缓存区的修改到远程仓库,这些操作帮助开发者有效管理代码版本和修改
    2024-10-10
  • vscode代码格式化和eslint的使用

    vscode代码格式化和eslint的使用

    这篇文章主要介绍了vscode代码格式化和eslint的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05
  • VsCode中ctrl+s后会在当前目录下自动生成dist目录的方法

    VsCode中ctrl+s后会在当前目录下自动生成dist目录的方法

    这篇文章主要介绍了VsCode中ctrl+s后会在当前目录下自动生成dist目录,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • 详解文法的定义与分类(编译原理)

    详解文法的定义与分类(编译原理)

    计算机的语言具有严格的语法、语义,易于形式化的特征,这篇文章主要介绍了详解文法的定义与分类(编译原理),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-08-08
  • VS Code快速生成html(头部)模板图文教程

    VS Code快速生成html(头部)模板图文教程

    这篇文章主要给大家介绍了关于VS Code快速生成html(头部)模板的相关资料,为了避免简单的重复劳动,借助VSCODE 快速生成文件头部,在项目搭建中体验非常舒适,需要的朋友可以参考下
    2023-11-11

最新评论