深入浅出 全面剖析消息队列(Kafka,RabbitMQ,RocketMQ 等)

消息队列

一、概念

  • 消息队列(MQ):一种异步通信机制,通过“消息”的形式让不同系统或模块解耦
  • 核心思想:发送方(生产者Producer)只负责发送消息,接收方(消费者Consumer)只负责消费消息,两者之间通过队列(Broker)传递消息
  • 优势:
    1. 系统解耦
    2. 异步处理,提高性能
    3. 削峰填谷(流量削峰,平稳处理高并发请求)
    4. 可靠通信(保证消息送达和消费)

二、底层实现原理

1. 基础模型
  • Producer(生产者):发送消息的程序/服务
  • Broker(消息中间件):消息存储与转发的核心
  • Consumer(消费者):接收并处理消息的程序
  • Queue / Topic
    • Queue(点对点,P2P):消息只会被一个消费者接收
    • Topic(发布/订阅,Pub/Sub):一个消息可以被多个消费者接收
2. 底层关键机制
  • 存储机制:磁盘顺序写(提高吞吐量)+ 内存缓存(加速访问)
  • 传输协议:TCP / HTTP / 自定义协议(Kafka使用TCP + 自定义协议)
  • 消息投递:支持同步投递、异步投递、批量投递
  • 可靠性保障:消息确认(ACK)、重试机制、持久化存储

三、各类MQ特点

1. Kafka
  • 定位:吞吐量高的分布式消息队列 & 流处理平台

  • 底层实现:

    • 顺序写磁盘 + 零拷贝(高性能I/O)
    • 分区(Partition) + 副本(Replica)保证扩展性与高可用
    • 消费者通过offset拉取消息,自行维护消费进度
  • 特点:

    • 高吞吐量,适合大数据场景
    • 保证消息顺序(分区内有序)
    • 不支持事务(0.11之后有支持,但是比较重)
  • 应用场景:

    • 日志收集系统(ELK、日志聚合)
    • 大数据实时流处理(Flink、Spark Steaming)
    • 高并发订单 / 交易消息处理
2. RabbitMQ
  • 定位:功能最强大、协议最完善的消息中间件
    • 消息中间件:包括消息队列、路由、持久化、事务、确认机制、协议支持等功能
  • 底层实现:
    • 基于Erlang开发
    • 使用AMQP协议(Advanced Message Queuing Protocol)
    • 支持消息路由(Exchange)+ 队列(Queue)
  • 特点:
    • 强调可靠行,强一致性(消息确认机制(ACK)、持久化、事务支持)
    • 路由灵活(Direct、Topic、Fanout、Headers)
    • 吞吐量相对Kafka低
  • 应用场景:
    • 电商订单系统(下单—>扣库存—>发货)
    • 任务异步执行(邮箱发送、短信推送)
    • 金融系统需要强一致性的场景
3. RocketMQ
  • 定位:阿里巴巴开源的高可用、高可靠分布式MQ
  • 底层实现:
    • 基于java开发
    • 消息存储基于CommitLog + ConsumeQueue索引机制
    • 支持顺序消息、延迟消息、事务消息
  • 特点:
    • 支持海量堆积(百万级消息堆积不影响性能)
    • 强调事务信息(保证最终一致性)
    • 性能接近Kafka,但支持更多企业级功能
  • 应用场景:
    • 电商交易系统(保证事务一致性)
    • 金融支付消息(高可靠)
    • 延迟任务(延迟队列)
3. Redis
  • 定位:缓存数据库,但也能充当轻量级消息队列
  • 实现方式:
    • List(LPUSH / RPOP)实现简单队列
    • Pub / Sub实现发布订阅模式
    • Redis Stream(5.0+)更强大,支持分组消费、持久化
  • 特点:
    • 极快,内存级性能
    • 可靠性差(宕机可能丢消息,除非持久化)
    • 不适合大规模复杂MQ场景
  • 应用场景:
    • 实时任务队列(轻量级异步任务)
    • 简单的发布订阅(聊天室、消息推送)
    • 作为Kafka / RabbitMQ的补充

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/98918.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/98918.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flux Images Generation API 对接说明

本文将介绍一种 Flux Images Generation API 对接说明,它是可以通过输入自定义参数来生成Flux官方的图片。 接下来介绍下 Flux Images Generation API 的对接说明。 申请流程 要使用 API,需要先到 Flux Images Generation API 对应页面申请对应的服务…

CSS布局 - 网格布局 -- 笔记3

目录网格布局基础网格网格剖析CSS 提供了一些控制网页布局的几个重要工具,这里介绍网格布局。 网格布局 CSS 网格可以定义由行和列组成的二维布局,然后将元素放置到网格中。有些元素可能只占据网格的一个单元,另一些元素则可能占据多行或多…

合约开发完后部署测试

一 编译npx hardhat compile二 测试npx hardhat test三部署注意部署的时候2.0和3版本有所区别,3.0如下# 部署到本地网络(如已运行 npx hardhat node) npx hardhat ignition deploy ./ignition/modules/MyModule.ts --network localhost# 部署…

产品无法正确解析复杂表格和流程图,有什么替代方案或优化方法?

在真实办公场景中,文档内的元素往往不具备标准化和格式化特征,像双栏表格、无线图表等复杂元素十分常见。而传统 OCR 工具在面对这类复杂文档时,存在明显的能力短板:它无法准确判断复杂表格的结构逻辑以及内容的顺序逻辑&#xff…

《Html模板》HTML数学题目生成器 - 让数学练习更简单(附源码)

目录专栏导读🧮 HTML数学题目生成器 - 让数学练习更简单项目简介✨ 核心功能🎯 灵活的运算类型选择📊 智能题目生成算法⚙️ 个性化参数设置🖨️ 专业打印优化🎨 用户体验设计现代化界面交互体验🛠️ 技术实…

Go语言设计模式(七)组合模式

组合模式是指将一组相似对象当做一个单一对象的设计模式.1.组成角色:1.1组件:组合中的对象声明接口,主要用于访问和管理其子组件.1.2叶子节点:定义组合中原始对象行为的类.叶子节点表示组合中的叶对象.1.3组合:又称为容器,存储子组件并在组件接口中实现与子组件有关的类.1.4客户…

AI 3D 生成工具知识库:当前产品格局与测评总结

聚焦于 AI 3D 生成领域的领军产品、功能比较及实测性能。内容分为产品格局、通用功能、测评系统与基准测试,以及单视图生成实测结果。所有信息基于脚本分析,并交叉验证了产品名称、团队背景(如 VAST AI 的 TripoSR/Meshy 的 Meshy-1、影眸科技…

淘客app的容器化部署与编排:基于Kubernetes的微服务架构实践

淘客app的容器化部署与编排:基于Kubernetes的微服务架构实践 大家好,我是阿可,微赚淘客系统及省赚客APP创始人,是个冬天不穿秋裤,天冷也要风度的程序猿! 在淘客app的业务迭代中,传统物理机部署面…

当GitHub不再纯粹:Python自动化测试的未来是AI还是危机?

全球最大的开源代码平台,彻底被卷进了AI洪流!作为全球最大的“程序员交友平台”(手动狗头),GitHub 可以说是每一个开发者又爱又恨的“家”。没错,就是那个全球最大、没有之一的开源代码托管平台&#xff01…

Spring Boot + MySQL 创建超级管理员

Spring Boot系统创建超管实现方式1. 数据库脚本初始化(最直接的方式)2. Spring Boot 启动时自动创建(代码级初始化)2.1 实体类定义2.2 Repository 接口2.3 初始化组件2.4 配置密码加密器3. 通过接口手动创建(最安全的方…

杨辉三角**

一、题目给定一个非负整数 numRows&#xff0c;生成「杨辉三角」的前 numRows 行。在「杨辉三角」中&#xff0c;每个数是它左上方和右上方的数的和。示例 1:输入: numRows 5 输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]]示例 2:输入: numRows 1 输出: [[1]]提示:1 <…

Vue3 的单文件组件(.vue 文件)中,在 <script>、<template>、<style> 标签外输入内容不会导致程序报错

在 <script>、<template>、<style> 标签外首行误输入内容 vtsvts <script setup lang"ts" name"BaseDocxPreviewDialog"> /*** docx文件预览模态框组件*/ defineOptions({ name: "BaseDocxPreviewDialog" }); import { …

LVS负载均衡群集和LVS+Keepalived群集

1、群集 1.1群集的含义 由多台主机构成&#xff0c;但对外只表现为一个整体&#xff0c;只提供一个访问入口&#xff08;域名与IP地址&#xff09;&#xff0c;相当于一台大型计算机。 1.2 企业群集分类 负载均衡群集&#xff1a;提高应用系统的响应能力、尽可能处理更多的…

LeetCode力扣-hot100系列(5)

这一篇主要讲一讲回溯&#xff0c;除了N皇后问题是困难题&#xff0c;不过N皇后知道了咋做也不难。回溯整体上还是好做的&#xff0c;直到套路容易做出来&#xff0c;题目容易理解。回溯[1]全排列问&#xff1a;给定一个不含重复数字的数组 nums &#xff0c;返回其 所有可能的…

机器学习05——多分类学习与类别不平衡(一对一、一对其余、多对多)

上一章&#xff1a;机器学习04——决策树 下一章&#xff1a;机器学习06——支持向量机 机器学习实战项目&#xff1a;【从 0 到 1 落地】机器学习实操项目目录&#xff1a;覆盖入门到进阶&#xff0c;大学生就业 / 竞赛必备 文章目录一、多分类学习&#xff08;一&#xff09;…

2025.9.11总结

阅读《拿铁因素》有感昨天看完《拿铁因素》&#xff0c;这本书让我明白&#xff0c;如果不去主动去管理自己的财务&#xff0c;解决自己从前的财务问题&#xff0c;我很难过上自己想要的生活。今天就所读的内容&#xff0c;探究如何将这本书的内容运用到自己的一个日常生活中。…

Android,Jetpack Compose,坦克大战游戏案例Demo

代码如下&#xff08;这只是个简单案例而已&#xff09;&#xff1a; package com.example.myapplicationimport android.os.Bundle import androidx.activity.ComponentActivity import androidx.activity.compose.setContent import androidx.compose.foundation.Canvas impo…

zookeeper是啥

ZooKeeper是一个开源的分布式协调服务&#xff0c;主要用于解决分布式系统中的数据一致性、状态同步和协作问题‌。它通过提供高可用、强一致性的服务&#xff0c;成为分布式系统的“指挥中心”‌。以下是其核心功能和应用场景&#xff1a;核心功能 分布式同步‌ 通过原子广播协…

【开题答辩全过程】以 基于Android的智慧旅游APP开发为例,包含答辩的问题和答案

个人简介一名14年经验的资深毕设内行人&#xff0c;语言擅长Java、php、微信小程序、Python、Golang、安卓Android等开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。感谢大家的…

如何选择?SEO 与 GEO 的 5 个核心分野

在 30 秒内&#xff0c;以下是您需要了解的有关 SEO 和 GEO 之间差异的信息&#xff1a; SEO&#xff08;搜索引擎优化&#xff09;&#xff1a;让您的网站出现在 Google 搜索中。目标&#xff1a;吸引用户点击您的链接。GEO&#xff08;生成引擎优化&#xff09;&#xff1a;…