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

从软件架构设计角度理解Kafka

网上对于消息中间件的介绍文章比较多,这里我们不再赘述,我们换个思路来理解消息中间件,从软件开发架构的角度来看下消息中间件是如何诞生和演进的。

一、概述

在这里插入图片描述
上图中P代表 Provider,C代表Consumer,下同。P和C是一个典型的生产消费者模式,也可以理解为客户和服务端。如果P生产效率为200qps(200/秒),而C的消费效率只有100qps,长此以往必将造成数据的积压,积压到一定程序应用就有可能崩溃了。

解决方案也先简单,架构方案的万能公式,通过中间层解决(当然了也可以再添加一个C形成一个消费集群,但这里我们暂时不讨论这种方案),如果加一层不行就再加一层。当然了如果能一层解决的最好不要再二层是不,这次的中间层就是消息中间件:Kafka。
在这里插入图片描述

二、消息中间件的由来

紧接上图描述,上面这种性能不对等的问题出现的一定会比kafka要早,那么当时是如何解决的呢?所以此处先忘掉kafka吧,让我们从头来看下kafka是如何沉淀出来的。
在这里插入图片描述
性能不对等,可以选择在C端加入一个中间管道-队列(Queue),即数据(消息Msg)先到达C端的队列中先缓冲一下,然后再传给消息程序正式处理(此处的数据在下文中就用消息来代替),这样就解决了Msg积压的问题也能保证所有的Msg全能被C消费。

看似性能不对等的问题解决了,但引入了另一个问题,就是Queue和C同属于同一个进程,如果C崩溃了话,未来得及消息的消息就全部丢失了,如下图所示:
在这里插入图片描述

三、消息中间件的设计演进

1、 Msg丢失问题

如何解决呢,方案也很简单,把Queue独立到单独进程中就可以了:
在这里插入图片描述
非常好,没啥问题了,消息不对等,数据丢失问题全解决了。回头看下初具消息中间件的样子了,但有一个问题就是在分布式生产环境下,上面的设计对于高性能、高可用、高扩展是一点没有提呀,如果Queue进程突然崩了,那这设计也真够糊弄人的。所以接下来还要考虑可用和稳定的问题

2、 高性能解决方案

这个问题很好理解呀,原来Queue的两端各是一个P和C,那么多增加几个就行了。
在这里插入图片描述
现在再看下,Queue现在可以同时连接多个P和C了,只要假设Queue足够NB,那么这个系统理论上就很无敌了,不过呢假设就是假设,先不说Queue性能有多好,就是无限的增加P之间的资源争抢也够Queue喝一壶的了,本来P1就要发1条消息,好吧还要等P2的10000条发完才能发,哭死了。如下图所示,好吗,白设计一圈了又回到了最原始的状态的。
在这里插入图片描述
分析上图,不就是Queue被争抢吗,那么多增加几个Queue不就行了,但这里的增加不是增加多个节点,而是把P1和P2发送的消息分离开,因为多增加节点还是解决不了问题,所以就有了下面的设计:

Topic设计

在这里插入图片描述
好吧,这样一区分,P1和P2的消息就分离开了,相互之间不再相互影响了,这里有了消息中间件的另一个概念:Topic:用于给不同类型消息定义一个标签。同样的P这边处理了,C端也存在资源争抢的问题呀,如下图:
在这里插入图片描述

Partition 设计

虽然P端的消息通过Topic隔离开了,但如果某个Topic消息过多,还是会产生同样的问题,现在上述的隔离方案又不能用了,怎么办呢?没啥好办法,还得隔离:
在这里插入图片描述
单队列再拆分吧,数据多了就分开放置,即采用Partition,这里就有了另一个概念。非常好,数据存储问题解决了。然后让C与Partition对应:
在这里插入图片描述
这样C也不会争抢资源了。至此,可以解决了大部分性能问题,但还是存在问题,即某个Patition中的消息过多,还是会存在C端性能问题

Consumer Group设计

既然有性能问题,那么就多加几个吧。
在这里插入图片描述
针对每个Patition对应一个消费组,每个组会从指定的队列位置消费消息,指定的位置在消息中间件中称为offset。

至此,好像性能问题没啥了,通过各种护展和分组解决的七七八八了,那么解决其它问题了哈。

3、高可用解决方案

上面我们对Queue的设计全是单机进行的,时间一长肯定会引发单点问题,这个是不可接受的。
在这里插入图片描述

Broker

解决吧,即然是单点,那就多加几个节点了。
在这里插入图片描述
如上图,我们把不同的Prtition放布到不同的节点上,这样可以减少一些单点问题。至少当机器A宕机了,只丢失了Partition1和Partition2的数据,还保留了一部分。没办法还得解决呀:

Replicas

增加副本吧,给机器A和B分别增加副本,使其数据保持一致,这样当机器A坏了,机器C顶上就行了,如果机器A和C同时坏了呢?那就增加了机器D,这样1主2副本同时坏的可能性不大了吧。
在这里插入图片描述
那么问题又来了,当机器A坏了,机器C咋顶上,谁来切换?总不能每次出问题了穿衣下地、打车去公司切吧,真要这样黄花菜都冻冰了。估计程序员也会凉凉了。所以还是自动吧。

Leader和Follower

怎么个自动法呢,好办,我们把主和副本机器分别标注一下角色,主称为Leader, 从称为Followr,然后呢再指定一个管理者Manager,然后让Manager与L和F互相通信,实时监控,这时当Leaer坏了,Manager就指定一个Follower为新的Leader,这样就成了一个自动切换程序了,程序员们也可以晚点凉凉了。
在这里插入图片描述
上面需要注意Leader和Follower不能位于同一个主机上呀,如果位于同一个机器上,那么Manager也无能为力了,所以要放在不一样的机器上。

我们已经做的很好了,但老天不做美,停机了,整个IDC机房都停电了。这回切也没用了,一锅端了
哎,还得解决呀。

manger 这种自动选举机制可集成zk这样的软件来处理。

4、 高扩展解决方案

如上,如果停机这东西无法处理,那么扯啥呢。解决吧,不就是丢数据吗,kafka数据在运行时数据是存放在内存中的。
在这里插入图片描述

那么存磁盘吧。
在这里插入图片描述
不错,当时存磁盘,来电了后重启服务从磁盘重新加载就行了。至于能不能全部恢复,那么就不再处理了吧(实际上可以做到0数据丢失)。到这差不多了。
可是,但可以是磁盘毕竟空间有限,你这成天往里存一会就爆了,内存是同样的道理

过期策略

没用的数据就删除了吧。
在这里插入图片描述
定几个超时策略吧,FIFO还是FILO自己按场景选择吧。

EN,差不多了,基本可用了吧。

四、 小结

一套组合拳下来,一个简单的队列,就完成了现在的MQ消息中间件了。起个名吧就中Kafka。
在这里插入图片描述

您学废了吗?

相关文章:

从软件架构设计角度理解Kafka

网上对于消息中间件的介绍文章比较多,这里我们不再赘述,我们换个思路来理解消息中间件,从软件开发架构的角度来看下消息中间件是如何诞生和演进的。 一、概述 上图中P代表 Provider,C代表Consumer,下同。P和C是一个典型…...

什么是中断?

1.什么是中断 2.中断的重要性 3.中断的上下半部 4.中断处理流程 中断的原则 5.ARM处理器程序运行过程 6.程序被被中断时,怎么保护现场 1.什么是中断 中断是指在 CPU 正常运行期间, 由外部或内部事件引起的一种机制。 当中断发生时,…...

后端(实例)08

设计一个前端在数据库调取数据的表格&#xff0c;并完成基础点击增删改查的功能&#xff1a; 1.首先写一个前端样式&#xff08;空壳&#xff09; <!DOCTYPE html> <html> <head> <meta charset"UTF-8"> <title>Insert title here&l…...

【stm32】TIM定时器输出比较-PWM驱动LED呼吸灯/舵机/直流电机

TIM定时器输出比较 一、输出比较简介1、OC&#xff08;Output Compare&#xff09;输出比较2、PWM简介3、输出比较通道(高级)4、输出比较通道(通用)5、输出比较模式6、PWM基本结构配置步骤&#xff1a;程序代码&#xff1a;PWM驱动LED呼吸灯 7、参数计算8、舵机简介程序代码&am…...

如何使用ssm实现线上旅游体验系统+vue

TOC ssm691线上旅游体验系统vue 绪论 课题背景 身处网络时代&#xff0c;随着网络系统体系发展的不断成熟和完善&#xff0c;人们的生活也随之发生了很大的变化。目前&#xff0c;人们在追求较高物质生活的同时&#xff0c;也在想着如何使自身的精神内涵得到提升&#xff0…...

探索JMeterTools:一个Python驱动的JMeter脚本生成器

JMeterTools 简介 JMeterTools 是一个由 Python 编写的开源项目&#xff0c;旨在帮助测试人员快速生成 JMeter 测试脚本。通过简单的 Python API&#xff0c;用户可以方便地定义测试计划、线程组、HTTP 请求等&#xff0c;可以结合接口自动化测试项目&#xff0c;将接口自动化…...

【React】组件通信

1. 组件通信 组件间的数据传递 1.1 父传子 步骤&#xff1a; 父组件传递数据——在子组件标签上绑定属性子组件接收数据——子组件通过props参数接收数据 function Son(props) {return <div>{props.value}</div> }function App() {const value 父组件传给子…...

C++核心编程和桌面应用开发 第七天(运算符重载 智能指针)

目录 1.数组类 2.运算符重载 2.1加号运算符 2.1.1成员函数实现 2.1.2全局函数实现 2.1.3加号重载 2.2左移运算符 2.3递增运算符 2.4指针运算符 2.5赋值运算符 1.数组类 //默认构造函数 MyArray::MyArray() {m_Size 0;m_Capacity 100;pAddress new int[m_Capacity]…...

echarts地图的简单使用

echarts地图的简单使用 文章说明核心源码效果展示源码下载 文章说明 主要介绍echarts地图组件的简单使用&#xff0c;记录为文章&#xff0c;供后续查阅使用 目前只是简单的示例&#xff0c;然后还存在着一些小bug&#xff0c;主要是首个Legend的点击会导致颜色全部不展示的问题…...

Qt 项目优化实践方向

目录 1. 使用智能指针2. 避免在全局或静态作用域中使用裸指针3. 利用Qt的对象树进行资源管理4. 延迟加载和按需加载资源5. 合理使用Qt的资源文件&#xff08;qrc&#xff09;6. 监控和调试内存使用7. 优化数据结构8. 减少不必要的资源复制9. 使用缓存机制10. 遵循RAII原则 以下…...

常见的15个:自然语言处理(NLP)实战项目

自然语言处理&#xff08;NLP&#xff09;实战项目涵盖了从基础到高级的多个领域&#xff0c;以下是一些常见的NLP实战项目&#xff0c;每个项目都附带了简要的描述和可能用到的技术栈&#xff1a; 1. 文本分类&#xff08;Text Classification&#xff09; 描述: 将文本数据…...

CKKS同态加密通用函数近似方法和openFHE实现

摘要 同态加密可以直接在密文上进行运算&#xff0c;尤其是CKKS&#xff0c;可以直接在实数的密文上进行运算。服务器可以利用强大的计算能力&#xff0c;在不泄露用户隐私的情况下&#xff0c;为用户提供便捷的外包运算服务。然而&#xff0c;CKKS只能进行算术运算&#xff0…...

Webpack 5的新特性:Asset Modules与Dynamic Import

文章目录 Asset ModulesAsset Modules 类型配置示例分析 Dynamic Import动态导入语法配置示例分析 实际案例分析Asset Modules 实际案例Dynamic Import 实际案例 性能优化Asset Modules 性能优化Dynamic Import 性能优化 详细代码分析Asset Modules 代码分析Dynamic Import 代码…...

解释python requests包的timeout

解释python requests包的timeout 哈哈哈。。。。垃圾python又来了 1 问题 你能看懂下面两个timeout的含义就不用看下面的内容了。 requests.get(http://example.com, timeout(2, 5)) requests.get(http://127.0.0.1:5000/api,timeout1)官网解释&#xff01;&#xff01;&am…...

蒙语学习快速方法,速记蒙语单词怎么学习更高效!

要高效学习蒙古语和速记单词&#xff0c;首先要掌握基础知识&#xff0c;如字母表和发音规则。接着&#xff0c;专注于学习日常用语和基础词汇&#xff0c;并运用记忆技巧如联想、发音和构词法来帮助记忆。利用专门的学习软件&#xff0c;如“蒙语学习通”&#xff0c;可以提供…...

Vue3组件通信13种方法

在 Vue3 中,组件之间的通信是构建应用程序的关键 1. 父组件向子组件传递数据 (Props)「父组件:」「子组件:」 2. 子组件向父组件传递数据 (Emit)「父组件:」「子组件:」 3. 兄弟组件通信 (Mitt)「发送事件的组件:」「接收事件的组件:」 4. 透传 Attributes ($attrs)「父组件:」…...

Servlet入门:服务端小程序的初试(自己学习整理的资料)

目录 一.前言 二.建立基础结构​编辑 三.具体步骤 找到Tomcat文件并打开Tomcat。 在webapps中创建一个自己的文件夹。 在classes中新建一个Java文件。 在lib中导入需要的jar文件包。 配置环境变量 在Java文件的目录下打开cmd并输入 javac -d . HelloServlet.java进行…...

代码随想录算法训练营第三七天| 动态规划:完全背包理论基础 518.零钱兑换II 377. 组合总和 Ⅳ 322. 零钱兑换

今日任务 动态规划&#xff1a;完全背包理论基础 518.零钱兑换II 377. 组合总和 Ⅳ 322. 零钱兑换 518.零钱兑换II 题目链接&#xff1a; . - 力扣&#xff08;LeetCode&#xff09; class Solution {public int change(int amount, int[] coins) {int[] dp new int[amount …...

[报错解决] 运行MATCHA时需要在线下载Arial.TTF字体,但是无法连接huggingface

一、报错详情 requests.exceptions.ConnectTimeout:(MaxRetryError("HTTPSConnectionPool(hosthuggingface.co, port443): Max retries exceeded with url: /ybelkada/fonts/resolve/main/Arial.TTF (Caused by ConnectTimeoutError(<urllib3.connection.HTTPSConnec…...

B-树(不是B减树)原理剖析(1)

目录 B树的主要特性&#xff1a; B树的操作&#xff1a; B树的优点&#xff1a; 为什么要发明出B-树&#xff1f; B树的概念和原理剖析 原理图讲解(部分讲解在图中) 初始化结点&#xff1a; 处理数据数量计算(了解) 底层代码实现(加深理解) 前些日子我们学了AVl树&…...

如何高效管理LiteDB数据库?LiteDB.Studio实战指南与深度解析

如何高效管理LiteDB数据库&#xff1f;LiteDB.Studio实战指南与深度解析 【免费下载链接】LiteDB.Studio A GUI tool for viewing and editing documents for LiteDB v5 项目地址: https://gitcode.com/gh_mirrors/li/LiteDB.Studio 在现代软件开发中&#xff0c;嵌入式…...

AudioLDM-S极速音效生成:5分钟搞定游戏音效,小白也能当音效师

AudioLDM-S极速音效生成&#xff1a;5分钟搞定游戏音效&#xff0c;小白也能当音效师 1. 游戏音效制作的新纪元 想象一下这样的场景&#xff1a;你正在开发一款独立游戏&#xff0c;需要一个"科幻飞船引擎启动"的音效。传统方式可能需要花费数小时搜索音效库、购买…...

WSL2下USB串口设备‘失踪’?手把手教你找回/dev/ttyUSB0(以Quectel模块为例)

WSL2下USB串口设备消失的终极解决方案&#xff1a;从原理到实战 最近在WSL2环境下调试Quectel模块时&#xff0c;发现一个奇怪现象&#xff1a;lsusb明明能识别设备&#xff0c;但/dev/ttyUSB0却神秘失踪。这让我想起去年调试树莓派时遇到的类似问题&#xff0c;但WSL2的环境特…...

trae中安装mcp报Cannot find package/ERR_MODULE_NOT_FOUND问题

简介 我在trae中安装高德地图的mcp和其他的mcp报出了以下错误&#xff0c;以此记录并分享给大家。 新的改变 node:internal/modules/esm/resolve:204 const resolvedOption FSLegacyMainResolve(pkgPath, packageConfig.main, baseStringified); ^ Error: Cannot find pack…...

s2-pro语音合成新玩法:用标签控制语气,轻松制作带情绪的语音内容

s2-pro语音合成新玩法&#xff1a;用标签控制语气&#xff0c;轻松制作带情绪的语音内容 1. 语音合成技术的新突破 在数字内容创作领域&#xff0c;语音合成技术正变得越来越重要。传统的语音合成系统往往只能生成单调、机械的语音&#xff0c;缺乏情感表达和自然韵律。而s2-…...

手把手教你用Qwen2.5-Omni-7B:一个模型搞定文本、图片、音频和视频(附Python代码示例)

实战Qwen2.5-Omni-7B&#xff1a;全模态AI开发指南 第一次听说一个模型能同时处理文本、图片、音频和视频时&#xff0c;我的反应和大多数开发者一样——既兴奋又怀疑。直到亲手用Python调用了Qwen2.5-Omni-7B的API&#xff0c;看着它准确描述视频内容、回答图片问题、甚至生成…...

Vue项目中天地图显示不全?试试这个MutationObserver的巧妙解法

Vue项目中天地图显示不全的终极解决方案&#xff1a;MutationObserver深度解析 第一次在Vue项目中集成天地图时&#xff0c;那种地图只渲染出一半的挫败感至今记忆犹新。控制台没有报错&#xff0c;API调用看起来也没问题&#xff0c;但地图就像被无形的剪刀裁切过一样&#xf…...

Gated DeltaNet 线性注意力:揭秘大模型算力魔咒的破局之道!

文章深入探讨了线性注意力机制在大模型中的重要性&#xff0c;特别是Gated DeltaNet如何通过改变运算顺序&#xff0c;将Transformer的注意力计算复杂度从平方级降低到线性级&#xff0c;从而打破算力瓶颈。文中对比了阿里Qwen、Kimi Linear等模型的线性架构应用&#xff0c;以…...

毕业设计实战:基于Java+MySQL的教务管理系统设计与实现指南

毕业设计实战&#xff1a;基于JavaMySQL的教务管理系统设计与实现指南 在开发“基于JavaMySQL的教务管理系统”毕业设计时&#xff0c;曾因课程报名表未通过学生ID与课程ID双外键关联踩过关键坑——初期仅设计报名编号、报名时间等基础字段&#xff0c;未与学生表、课程表建立关…...

四管升降压电路实战解析:从拓扑原理到模式切换(附波形对比)

1. 四管升降压电路为何成为工程师的"瑞士军刀" 第一次接触四管升降压电路时&#xff0c;我正被一个光伏储能项目折磨得焦头烂额。太阳能板的输出电压在8V-18V剧烈波动&#xff0c;而系统需要稳定的12V供电。传统方案要用两个独立电路串联&#xff0c;直到老工程师扔给…...