消息队列篇--原理篇--常见消息队列总结(RabbitMQ,Kafka,ActiveMQ,RocketMQ,Pulsar)
1、RabbitMQ
特点:
- AMQP协议:RabbitMQ是基于AMQP(高级消息队列协议)构建的,支持多种消息传递模式,如发布/订阅、路由、RPC等。
- 多语言支持:支持多种编程语言的客户端库,包括Java、Python、Node.js、Go等。
- 易用性:RabbitMQ的配置和使用相对简单,适合中小规模的应用。
- 持久化与可靠性:支持消息持久化,确保消息在系统故障时不会丢失。它还提供了多种消息确认机制(如ACK),以保证消息的可靠传递。
- 灵活性:RabbitMQ提供了丰富的路由规则和交换器类型(如Direct、Fanout、Topic、Headers),可以根据不同的业务需求灵活配置消息路由。
- 社区支持:RabbitMQ由VMware开发,后来捐赠给Pivotal Software,拥有活跃的社区和良好的文档支持。
适用场景:
- 中小型应用:RabbitMQ适合处理中小规模的消息队列需求,特别是在需要复杂的消息路由和灵活的消息传递模式的场景中。
- 微服务架构:RabbitMQ常用于微服务之间的异步通信,尤其是在需要解耦服务和处理异步任务的场景中。
- 企业级应用:RabbitMQ在企业级应用中广泛使用,特别是在金融、电商等行业。
缺点:
- 性能限制:相比Kafka和Pulsar,RabbitMQ的吞吐量较低,不适合处理大规模数据流。
- 扩展性:虽然RabbitMQ支持集群,但在大规模分布式环境中,扩展性和性能可能会受到限制。
2、Kafka
特点:
- 高吞吐量:Kafka以其出色的吞吐量著称,每秒可以处理数十万条消息,特别适合处理大规模数据流。
- 低延迟:Kafka消息传递的延迟非常低,通常在几毫秒内完成,适合实时数据分析和流处理。
- 分区与副本:Kafka使用分区(Partition)和副本(Replica)机制来实现水平扩展和高可用性。每个主题可以被分割为多个分区,分区的数据分布在集群中的不同Broker上。
- 持久化与压缩:Kafka支持消息的持久化存储,并且可以通过批量发送和压缩机制提高传输效率。
- 生态系统丰富:Kafka拥有庞大的生态系统,与Hadoop、Spark、Flink等大数据工具集成紧密,适合用于日志收集、实时分析等大数据处理场景。
- ZooKeeper依赖:Kafka依赖ZooKeeper来管理集群元数据和协调选举,但正在开发KIP-500项目以摆脱对ZooKeeper的依赖。
适用场景:
- 大数据处理:Kafka适合处理海量数据流,特别是在需要实时分析、日志收集、流处理等场景中。
- 实时分析:Kafka的低延迟特性使其成为实时数据分析的理想选择,尤其是在金融、广告、物联网等领域。
- 日志收集:Kafka常用于日志收集和聚合,能够高效地处理大量的日志数据。
缺点:
- 复杂性:随着Partition数量的增加,管理和再平衡的操作可能会变得复杂。
- 消息顺序:Kafka只提供分区级别的消息顺序保证,在某些情况下可能会导致消息乱序。
3、ActiveMQ
特点:
- JMS标准:ActiveMQ是一个基于JMS(Java 消息服务)标准的消息队列系统,支持多种消息传递模式,如点对点(P2P)和发布/订阅(Pub/Sub)。
- 多协议支持:除了JMS,ActiveMQ还支持AMQP、STOMP、MQTT等多种协议,适用于不同的应用场景。
- 持久化与可靠性:ActiveMQ支持消息持久化,确保消息在系统故障时不会丢失。它还提供了多种消息确认机制(如ACK),以保证消息的可靠传递。
- 易于集成:ActiveMQ与Java生态系统紧密集成,适合Java应用程序的开发。
- 插件化架构:ActiveMQ提供了丰富的插件机制,可以根据需要扩展功能,如安全性、监控、消息过滤等。
- 社区支持:ActiveMQ由Apache软件基金会维护,拥有活跃的社区和良好的文档支持。
适用场景:
- Java应用:ActiveMQ适合Java应用程序的开发,特别是在需要与JMS兼容的场景中。
- 企业级应用:ActiveMQ在企业级应用中广泛使用,特别是在需要可靠的消息传递和复杂的集成需求的场景中。
- 小型到中型应用:ActiveMQ适合处理小型到中型的消息队列需求,特别是在需要灵活的消息传递模式和多协议支持的场景中。
缺点:
- 性能限制:相比Kafka和Pulsar,ActiveMQ的吞吐量较低,不适合处理大规模数据流。
- 扩展性:虽然ActiveMQ支持集群,但在大规模分布式环境中,扩展性和性能可能会受到限制。
4、RocketMQ
特点:
- 高性能:RocketMQ同样具备高吞吐量和低延迟的特点,尤其在处理大规模消息传递方面表现出色。
- 高可靠性:RocketMQ支持同步双写和异步刷盘两种模式,确保消息不丢失,特别是在电商等场景下表现优异。
- 顺序写入:所有消息不分主题一律顺序写入commitlog文件,这有助于提高磁盘I/O效率。
- 队列模型:RocketMQ单机支持最高5万个队列,使得它在处理大量队列时仍能保持稳定的性能。
- 功能丰富:RocketMQ提供了丰富的功能特性,如消息过滤、事务消息、延迟消息、顺序消息等。这些特性使得RocketMQ能够更灵活地满足各种业务需求。
- Java生态友好:RocketMQ主要在中国开发者社区中受到广泛关注,与阿里巴巴的其他技术栈(如Dubbo、Spring Cloud Alibaba等)有较好的集成。
适用场景:
- 电商和金融:RocketMQ适合对数据可靠性、实时性要求较高的场景,如金融交易、订单处理等。
- 大规模消息传递:RocketMQ能够处理数百万级别的消息队列,适合需要处理大量队列的场景。
- Java 生态:RocketMQ与Java技术栈紧密集成,适合已经在使用Java技术栈的企业。
缺点:
- 社区较小:相比Kafka和Pulsar,RocketMQ的社区相对较小,虽然在中国有广泛的用户基础,但在全球范围内的影响力有限。
- 运维复杂度:RocketMQ的API简单,易于集成,但由于其与阿里巴巴技术栈的紧密集成,在非阿里巴巴技术栈环境中部署和运维的复杂度可能会有所增加。
5、Pulsar
特点:
- 分层架构:Pulsar采用两层架构,分为Broker层和BookKeeper层。Broker层负责接收和发送消息,BookKeeper层则负责存储消息,并处理副本的复制和恢复。这种架构使得计算和存储可以独立扩展,降低了扩展的复杂性。
- 强一致性:Pulsar提供严格的消息顺序保证,特别是在跨多个分区的情况下。这对于需要强一致性的应用场景(如金融交易、订单处理等)非常重要。
- 多租户支持:Pulsar内置了丰富的多租户支持,包括租户、命名空间的概念,可以为不同的租户设置资源配额、访问控制等。这对于云环境和大型企业内部的复杂场景非常有用。
- 跨地域部署:Pulsar专门为跨地域部署设计,提供了强大的全球复制能力,能够轻松实现跨多个数据中心的消息传递。
- 低延迟与高吞吐量:根据一些基准测试,在相同条件下,Pulsar的吞吐量比Kafka高出40%到60%,并且平均延迟通常比Kafka低50%以上,特别是在高并发场景下表现更佳。(注:吞吐量(Throughput)指的是在单位时间内系统能够处理的工作量或数据量,是衡量系统处理能力的一个关键指标。)
- 云原生友好:Pulsar与Kubernetes等云原生技术栈集成良好,适合现代微服务架构和容器化部署。
适用场景:
- 跨地域部署:Pulsar适合需要在全球范围内分布的应用,特别是在需要跨多个数据中心的消息传递的场景中。
- 强一致性:Pulsar适合对消息顺序和一致性要求较高的应用场景,如金融交易、订单处理等。
- 多租户支持:Pulsar适合需要在同一集群中支持多个独立租户或团队的场景,特别是在云环境中。
- 云原生架构:Pulsar适合正在向云原生架构转型的企业,特别是那些已经使用容器化、微服务等现代技术栈的企业。
缺点:
- 学习曲线:Pulsar的架构比Kafka更复杂,初期的学习曲线可能较陡,尤其是对于不熟悉其设计的团队。
- 社区较小:虽然Pulsar的社区增长迅速,但它仍然相对较小,尤其是在全球范围内的影响力有限。
6、总结

Kafka、Pulsar、RabbitMQ、ActiveMQ和RocketMQ都是非常优秀的消息队列系统,选择哪一个取决于你的具体需求。Pulsar和Kafka在性能和扩展性方面表现出色,适合处理大规模数据流和实时分析;RabbitMQ和ActiveMQ更适合中小规模的应用和企业级需求;RocketMQ则在电商和金融领域表现出色,特别是在需要高可靠性和大规模消息传递的场景中。
7、如何选择
- 如果你的应用需要:
- 高吞吐量和低延迟:Kafka和Pulsar是更好的选择,特别是在处理大规模数据流和实时分析的场景中。
- 强一致性和多租户支持:Pulsar是更好的选择,特别是在需要跨多个分区的消息顺序保证和多租户支持的场景中。
- 跨地域部署:Pulsar是更好的选择,特别是在需要在全球范围内分布的应用中。
- 易用性和简单的运维:RabbitMQ和ActiveMQ是更好的选择,特别是在中小规模的应用中,或者你需要快速上手和简单配置的场景。
- Java生态友好以及电商金融领域:RocketMQ是更好的选择,特别是在你已经在使用Java技术栈的企业中。
乘风破浪会有时,直挂云帆济沧海!!!
相关文章:
消息队列篇--原理篇--常见消息队列总结(RabbitMQ,Kafka,ActiveMQ,RocketMQ,Pulsar)
1、RabbitMQ 特点: AMQP协议:RabbitMQ是基于AMQP(高级消息队列协议)构建的,支持多种消息传递模式,如发布/订阅、路由、RPC等。多语言支持:支持多种编程语言的客户端库,包括Java、P…...
【力扣每日一题】存在重复元素 II 解题思路
219. 存在重复元素 II 解题思路 问题描述 给定一个整数数组 nums 和一个整数 k,要求判断数组中是否存在两个 不同的索引 i 和 j,使得: nums[i] nums[j]且满足 abs(i - j) < k 如果满足上述条件,返回 true,否则…...
React第二十八章(css modules)
css modules 什么是 css modules 因为 React 没有Vue的Scoped,但是React又是SPA(单页面应用),所以需要一种方式来解决css的样式冲突问题,也就是把每个组件的样式做成单独的作用域,实现样式隔离,而css modules就是一种…...
本地运行大模型效果及配置展示
电脑上用ollama安装了qwen2.5:32b,deepseek-r1:32b,deepseek-r1:14b,llama3.1:8b四个模型,都是Q4_K_M量化版。 运行过程中主要是cpu和内存负载比较大,qwen2.5:32b大概需要22g,deepseek-r1:32b类…...
愿景:做机器视觉行业的颠覆者
一个愿景,两场战斗,专注制胜。 一个愿景:做机器视觉行业的颠覆者。 我给自己创业,立一个大的愿景:做机器视觉行业的颠覆者。 两场战斗:无监督-大模型 上半场,无监督。2025-2030,共五…...
arm-linux-gnueabihf安装
Linaro Releases windows下打开wsl2中的ubuntu,资源管理器中输入: \\wsl$gcc-linaro-4.9.4-2017.01-x86_64_arm-linux-gnueabihf.tar.xz 复制到/home/ark01/tool 在 Ubuntu 中创建目录: /usr/local/arm,命令如下: …...
力扣动态规划-16【算法学习day.110】
前言 ###我做这类文章一个重要的目的还是给正在学习的大家提供方向(例如想要掌握基础用法,该刷哪些题?建议灵神的题单和代码随想录)和记录自己的学习过程,我的解析也不会做的非常详细,只会提供思路和一些关…...
Java基础知识总结(三十四)--java.util.Date
月份从0-11; /* 日期对象和毫秒值之间的转换。 1,日期对象转成毫秒值。Date类中的getTime方法。 2,如何将获取到的毫秒值转成具体的日期呢? Date类中的setTime方法。也可以通过构造方法。 */ //日期对象转成毫秒值 Date …...
零售EDI:Costco EDI 项目须知
Costco 是全球领先的会员制仓储式零售商,致力于为会员提供高品质且价格实惠的商品。其经营范围涵盖食品、电子产品、家居用品、服装和办公设备等多个领域。 Costco 的 EDI 对接需求分析 为了更高效地管理其复杂的全球供应链,Costco 采用了先进的 EDI&am…...
最近最少使用算法(LRU最近最少使用)缓存替换算法
含义 最近最少使用算法(LRU)是一种缓存替换算法,用于在缓存空间有限的情况下,选择最少使用的数据项进行替换。该算法的核心思想是基于时间局部性原理,即刚被访问的数据在未来也很有可能被再次访问。 实现 LRU算法的…...
sublime_text的快捷键
sublime_text的快捷键 向下复制, 复制光标所在整行并插入到下一行:通过 CtrlShiftD 实现快速复制当前行的功能。 可选多行, 不选则复制当前行 ctrl Shift D 删除当前行:通过 CtrlShiftK 实现快速删除当前行的功能。 可选多行, 不选则删当前行 ctrl S…...
使用Pygame制作“贪吃蛇”游戏
贪吃蛇 是一款经典的休闲小游戏:玩家通过操控一条会不断变长的“蛇”在屏幕中移动,去吃随机出现的食物,同时要避免撞到墙壁或自己身体的其他部分。由于其逻辑相对简单,但可玩性和扩展性都不错,非常适合作为新手练习游戏…...
本地部署DeepSeek开源多模态大模型Janus-Pro-7B实操
本地部署DeepSeek开源多模态大模型Janus-Pro-7B实操 Janus-Pro-7B介绍 Janus-Pro-7B 是由 DeepSeek 开发的多模态 AI 模型,它在理解和生成方面取得了显著的进步。这意味着它不仅可以处理文本,还可以处理图像等其他模态的信息。 模型主要特点:Permalink…...
Java开发vscode环境搭建
1 几个名词 JDK Java Development Kit JRE Java Runtion Environment JVM JDK 包括 Compiler,debugger,JRE等。JRE包括JVM和Runtime Library。 2 配置环境 2.1 安装JDK 类比 C/C的 g工具 官网:https://www.oracle.com/java/technologies/downloads/ 根据自己使…...
深入解析:一个简单的浮动布局 HTML 示例
深入解析:一个简单的浮动布局 HTML 示例 示例代码解析代码结构分析1. HTML 结构2. CSS 样式 核心功能解析1. 浮动布局(Float)2. 清除浮动(Clear)3. 其他样式 效果展示代码优化与扩展总结 在网页设计中,浮动…...
车载软件 --- 大一新生入门汽车零部件嵌入式开发
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 简单,单纯,喜欢独处,独来独往,不易合同频过着接地气的生活…...
DDD - 领域驱动设计分层架构:构建可演化的微服务架构
文章目录 引言1. 什么是DDD分层架构?1.1 DDD分层架构的演变1.2 四层架构的起源与问题1.3 依赖倒置和五层架构 2. DDD分层架构的核心层次2.1 用户接口层(User Interface Layer)2.2 应用层(Application Layer)2.3 领域层…...
2025数学建模美赛|赛题翻译|E题
2025数学建模美赛,E题赛题翻译 更多美赛内容持续更新中......
DeepSeek-V3 与 DeepSeek R1 对比分析:技术与应用的全面解析
一、背景 在当今科技飞速发展的时代,深度学习技术如同一股强大的浪潮,席卷了自然语言处理(NLP)、计算机视觉(CV)以及多模态模型等众多领域。从智能语音助手到图像识别技术,从文本生成工具到多模…...
qt-Quick3D笔记之官方例程Runtimeloader Example运行笔记
qt-Quick3D笔记之官方例程Runtimeloader Example运行笔记 文章目录 qt-Quick3D笔记之官方例程Runtimeloader Example运行笔记1.例程运行效果2.例程缩略图3.项目文件列表4.main.qml5.main.cpp6.CMakeLists.txt 1.例程运行效果 运行该项目需要自己准备一个模型文件 2.例程缩略图…...
<6>-MySQL表的增删查改
目录 一,create(创建表) 二,retrieve(查询表) 1,select列 2,where条件 三,update(更新表) 四,delete(删除表…...
理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端
🌟 什么是 MCP? 模型控制协议 (MCP) 是一种创新的协议,旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议,它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...
蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练
前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1):从基础到实战的深度解析-CSDN博客,但实际面试中,企业更关注候选人对复杂场景的应对能力(如多设备并发扫描、低功耗与高发现率的平衡)和前沿技术的…...
在QWebEngineView上实现鼠标、触摸等事件捕获的解决方案
这个问题我看其他博主也写了,要么要会员、要么写的乱七八糟。这里我整理一下,把问题说清楚并且给出代码,拿去用就行,照着葫芦画瓢。 问题 在继承QWebEngineView后,重写mousePressEvent或event函数无法捕获鼠标按下事…...
推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材)
推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材) 这个项目能干嘛? 使用 gemini 2.0 的 api 和 google 其他的 api 来做衍生处理 简化和优化了文生图和图生图的行为(我的最主要) 并且有一些目标检测和切割(我用不到) 视频和 imagefx 因为没 a…...
Go 并发编程基础:通道(Channel)的使用
在 Go 中,Channel 是 Goroutine 之间通信的核心机制。它提供了一个线程安全的通信方式,用于在多个 Goroutine 之间传递数据,从而实现高效的并发编程。 本章将介绍 Channel 的基本概念、用法、缓冲、关闭机制以及 select 的使用。 一、Channel…...
Caliper 负载(Workload)详细解析
Caliper 负载(Workload)详细解析 负载(Workload)是 Caliper 性能测试的核心部分,它定义了测试期间要执行的具体合约调用行为和交易模式。下面我将全面深入地讲解负载的各个方面。 一、负载模块基本结构 一个典型的负载模块(如 workload.js)包含以下基本结构: use strict;/…...
从面试角度回答Android中ContentProvider启动原理
Android中ContentProvider原理的面试角度解析,分为已启动和未启动两种场景: 一、ContentProvider已启动的情况 1. 核心流程 触发条件:当其他组件(如Activity、Service)通过ContentR…...
Spring Security 认证流程——补充
一、认证流程概述 Spring Security 的认证流程基于 过滤器链(Filter Chain),核心组件包括 UsernamePasswordAuthenticationFilter、AuthenticationManager、UserDetailsService 等。整个流程可分为以下步骤: 用户提交登录请求拦…...
C++--string的模拟实现
一,引言 string的模拟实现是只对string对象中给的主要功能经行模拟实现,其目的是加强对string的底层了解,以便于在以后的学习或者工作中更加熟练的使用string。本文中的代码仅供参考并不唯一。 二,默认成员函数 string主要有三个成员变量,…...
