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

RabbitMQ和RocketMQ,哪个更好?

前言最近有球友问我苏三哥现在一般的项目中的消息中间件是用RabbitMQ还是RocketMQ更好这是一个非常常见的问题。今天这篇文章就专门跟大家一起聊聊这个话题希望对你会有所帮助。一、为什么需要消息队列有些小伙伴在工作中可能已经用过消息队列但未必清楚它的核心价值。让我们先通过一个简单的场景来理解没有消息队列的系统RestControllerpublicclassOrderController{AutowiredprivateInventoryServiceinventoryService;AutowiredprivatePromotionServicepromotionService;AutowiredprivateLogServicelogService;PostMapping(/order)publicResultcreateOrder(RequestBodyOrderRequestrequest){// 串行调用多个服务用户需要等待所有操作完成inventoryService.deductStock(request.getProductId(),request.getQuantity());promotionService.updatePromotionUsage(request.getUserId(),request.getPromotionId());logService.recordOrderLog(request);returnResult.success(下单成功);}}引入消息队列后RestControllerpublicclassOrderController{AutowiredprivateOrderServiceorderService;AutowiredprivateRocketMQTemplaterocketMQTemplate;PostMapping(/order)publicResultcreateOrder(RequestBodyOrderRequestrequest){// 1. 保存订单主记录核心业务OrderorderorderService.saveOrder(request);// 2. 发送消息异步处理非核心业务OrderCreatedEventeventnewOrderCreatedEvent(order);rocketMQTemplate.send(order-topic,event);// 3. 立即返回成功returnResult.success(订单创建成功处理中);}}// 消费者异步处理ComponentRocketMQMessageListener(topicorder-topic,consumerGrouporder-group)publicclassOrderConsumerimplementsRocketMQListenerOrderCreatedEvent{OverridepublicvoidonMessage(OrderCreatedEventevent){// 并行执行多个操作但用户无需等待inventoryService.deductStock(event.getProductId(),event.getQuantity());promotionService.updatePromotionUsage(event.getUserId(),event.getPromotionId());logService.recordOrderLog(event);}}消息队列的核心价值在于解耦、异步、削峰。但不同的消息队列在实现这些价值时侧重点各不相同。其实咱们的星球中的商城微服务系统、秒杀系统、SaaS点餐系统就大量使用了MQ实现相关业务逻辑。比如异步海量数据导出功能、WebSocket消息实时通信功能、商品秒杀功能、订单超时自动取消功能等等。更多项目实战在项目实战网Java突击队二、核心特性对比让我们先通过一个表格直观感受两者的核心差异对比维度RabbitMQRocketMQ吞吐量(TPS)5-10K50K延迟(ms)50-10020-50协议支持AMQP、MQTT、STOMP等7种协议自定义TCP协议为主路由机制4种Exchange灵活路由Topic模型相对简单事务消息不支持支持定时/延时消息插件支持原生支持秒级精度顺序消息单队列保证全局/分区顺序支持开发语言ErlangJava社区活跃度极高生态丰富较高阿里生态为主三、RabbitMQ解析3.1 RabbitMQ的核心优势有些小伙伴可能对RabbitMQ的灵活路由机制印象深刻。确实这是RabbitMQ最强大的特性之一。RabbitMQ的四种交换机类型代码示例Topic交换机实现复杂路由// RabbitMQ配置类ConfigurationpublicclassRabbitMQConfig{BeanpublicTopicExchangeorderExchange(){returnnewTopicExchange(order.exchange);}BeanpublicQueuepaymentQueue(){returnQueueBuilder.durable(payment.queue).build();}BeanpublicQueueinventoryQueue(){returnQueueBuilder.durable(inventory.queue).build();}BeanpublicBindingpaymentBinding(){returnBindingBuilder.bind(paymentQueue()).to(orderExchange()).with(order.payment.*);}BeanpublicBindinginventoryBinding(){returnBindingBuilder.bind(inventoryQueue()).to(orderExchange()).with(order.inventory.*);}}// 生产者ServicepublicclassOrderProducer{AutowiredprivateRabbitTemplaterabbitTemplate;publicvoidsendOrderEvent(StringeventType,OrderEventevent){// routingKey可以是 order.payment.success 或 order.inventory.updaterabbitTemplate.convertAndSend(order.exchange,order.eventType,event);}}// 消费者 - 支付服务ComponentRabbitListener(queuespayment.queue)publicclassPaymentConsumer{RabbitHandlerpublicvoidhandlePayment(OrderEventevent){System.out.println(支付服务处理event);}}// 消费者 - 库存服务ComponentRabbitListener(queuesinventory.queue)publicclassInventoryConsumer{RabbitHandlerpublicvoidhandleInventory(OrderEventevent){System.out.println(库存服务处理event);}}RabbitMQ的另一个优势是多协议支持。它原生支持AMQP 0-9-1、AMQP 1.0、MQTT、STOMP等多种协议这在物联网、移动端等异构系统集成时非常有用。3.2 RabbitMQ的局限性虽然RabbitMQ灵活易用但它也存在一些明显的短板性能瓶颈单节点吞吐量约5-10K TPS在百万级消息/秒场景下Erlang虚拟机可能成为性能瓶颈。集群扩展复杂依赖镜像队列实现高可用增加存储开销网络分区处理较为复杂。顺序消息困难默认不保证跨消费者的消息顺序。事务机制不完善RabbitMQ的事务机制会极大影响性能官方也不推荐使用。3.3 RabbitMQ适用场景推荐使用场景中小规模微服务系统消息量10万级/秒需要复杂路由逻辑的业务如订单状态变更通知多协议接入场景IoT设备、移动端、WebSocket对可靠性要求高于性能的企业级应用不推荐场景超大规模日志处理首选Kafka严格顺序要求的金融交易考虑RocketMQ极低延迟需求的高频交易场景更多项目实战在项目实战网Java突击队四、RocketMQ解析4.1 RocketMQ的核心优势RocketMQ是阿里巴巴开源的分布式消息中间件在电商、金融等大规模分布式系统中表现优异。RocketMQ的高可用架构RocketMQ的核心特性代码示例1. 事务消息RocketMQ的王牌特性ComponentpublicclassTransactionOrderService{AutowiredprivateRocketMQTemplaterocketMQTemplate;AutowiredprivateOrderMapperorderMapper;// 发送事务消息publicvoidcreateOrderWithTransaction(OrderRequestrequest){OrderMessageorderMessagenewOrderMessage(request);TransactionSendResultresultrocketMQTemplate.sendMessageInTransaction(order-tx-group,order-topic,MessageBuilder.withPayload(orderMessage).build(),request// 传递给本地事务执行器的参数);if(result.getLocalTransactionState()LocalTransactionState.COMMIT_MESSAGE){System.out.println(事务提交成功);}}// 本地事务执行器RocketMQTransactionListener(txProducerGrouporder-tx-group)publicclassOrderTransactionListenerimplementsRocketMQLocalTransactionListener{OverridepublicRocketMQLocalTransactionStateexecuteLocalTransaction(Messagemsg,Objectarg){OrderRequestrequest(OrderRequest)arg;try{// 1. 执行本地事务 - 保存订单orderMapper.insert(request);// 2. 返回提交状态returnRocketMQLocalTransactionState.COMMIT;}catch(Exceptione){// 3. 异常时回滚returnRocketMQLocalTransactionState.ROLLBACK;}}OverridepublicRocketMQLocalTransactionStatecheckLocalTransaction(Messagemsg){// 事务回查 - 解决分布式事务的最终一致性OrderMessageorderMessage(OrderMessage)msg.getPayload();// 查询本地事务是否成功OrderorderorderMapper.selectById(orderMessage.getOrderId());if(order!null){returnRocketMQLocalTransactionState.COMMIT;}else{returnRocketMQLocalTransactionState.ROLLBACK;}}}}2. 精确到秒级的定时消息RocketMQ 5.x版本引入了秒级定时消息这是通过时间轮算法实现的ServicepublicclassDelayMessageService{AutowiredprivateRocketMQTemplaterocketMQTemplate;// 发送定时消息精确到秒publicvoidsendDelayMessage(MessageDatadata,longdelaySeconds){longdelayTimestampSystem.currentTimeMillis()delaySeconds*1000;MessageMessageDatamessageMessageBuilder.withPayload(data).setHeader(DELAY_TIME,delayTimestamp).build();rocketMQTemplate.syncSend(delay-topic,message);}// 消费定时消息ServiceRocketMQMessageListener(topicdelay-topic,consumerGroupdelay-group)publicclassDelayMessageConsumerimplementsRocketMQListenerMessageData{OverridepublicvoidonMessage(MessageDatamessage){System.out.println(定时消息到达message);}}}RocketMQ的定时消息底层通过时间轮TimerWheel TimerLog实现这种设计保证了即使消息延迟时间很长如半个月也不会丢失。3. 顺序消息实现ServicepublicclassOrderlyMessageService{AutowiredprivateRocketMQTemplaterocketMQTemplate;// 发送顺序消息 - 按订单ID路由publicvoidsendOrderlyMessage(StringorderId,OrderEventevent){// 通过MessageQueueSelector将同一订单的消息发送到同一个队列rocketMQTemplate.syncSendOrderly(order-topic,event,orderId// 选择key);}// 顺序消费ServiceRocketMQMessageListener(topicorder-topic,consumerGrouporderly-group,consumeModeConsumeMode.ORDERLY// 顺序消费模式)publicclassOrderlyConsumerimplementsRocketMQListenerOrderEvent{OverridepublicvoidonMessage(OrderEventevent){// 保证同一订单的消息串行处理System.out.println(顺序处理订单事件event);}}}4.2 RocketMQ的局限性协议封闭主要支持自定义TCP协议多语言客户端支持较弱社区生态相比RabbitMQ生态规模较小主要在阿里生态中活跃学习曲线概念较多NameServer、Broker、Queue等入门门槛略高运维复杂度需要部署NameServer和Broker集群运维成本相对较高4.3 RocketMQ适用场景推荐使用场景电商交易系统订单、支付、库存金融核心系统需要事务一致性大规模分布式系统消息量10万级/秒需要严格顺序消息的业务如交易流水需要定时/延时消息的场景不推荐场景多协议接入需求首选RabbitMQ简单的内部系统Kafka或RabbitMQ更轻量非Java技术栈为主的项目更多项目实战在项目实战网Java突击队五、如何选型5.1 决策树5.2 关键决策因素选择RabbitMQ当需要复杂消息路由Topic、Direct、Fanout等需要支持多种协议MQTT、AMQP、STOMP团队熟悉Erlang或对运维复杂度敏感消息量适中10万TPS选择RocketMQ当需要分布式事务支持需要严格顺序消息需要精准定时/延时消息系统规模较大10万TPSJava技术栈为主5.3 混合架构方案在实际项目中完全可以采用混合架构架构方案-主干消息:RocketMQ用途:核心交易、订单、支付理由:事务保证、高吞吐-分支消息:RabbitMQ用途:通知推送、日志收集、IoT设备理由:多协议支持、灵活路由-监控体系:-Prometheus Grafana-队列积压监控-消费延迟告警更多项目实战在项目实战网Java突击队总结通过本文我们可以得出以下结论RabbitMQ胜在灵活性和协议兼容性适合企业级应用集成、复杂路由场景。RocketMQ胜在功能全面和性能优势特别适合电商、金融等需要事务保证和顺序消息的场景。没有绝对的优劣只有最适合的选择。选择消息队列时需要综合考虑业务需求事务、顺序、定时性能要求吞吐量、延迟技术栈Java/非Java运维能力关注技术演进RocketMQ 5.x在定时消息、高可用等方面持续创新RabbitMQ也在引入Quorum Queues等增强一致性。建议每18个月重新评估技术栈。最后送给大家一句话选型不是终点理解才是关键。只有深入理解消息队列的原理才能在遇到问题时游刃有余。如果你有任何问题或经验分享欢迎在评论区交流讨论

相关文章:

RabbitMQ和RocketMQ,哪个更好?

前言 最近有球友问我:苏三哥,现在一般的项目中的消息中间件,是用RabbitMQ,还是RocketMQ,更好? 这是一个非常常见的问题。 今天这篇文章就专门跟大家一起聊聊这个话题,希望对你会有所帮助。 …...

c++11的列表初始化及其底层原理

在c98中,只允许数组和结构体的元素使用列表进行初始化但是在c11中,可以使用列表对所有的元素进行初始化在使用{}进行初始化的时候,可以添加,也可以不添加int a { 10 }; int b{ 10 }; int* pa new int[4] {0}; int arr[3]{ 1,2,3 }; pair<int, string >{1, "222&qu…...

PC端U盘防复制软件|Windows USB接口权限管控工具

温馨提示&#xff1a;文末有联系方式产品定位&#xff1a;专业级PC端USB存储设备安全管控方案 本工具是一款专为Windows系统设计的轻量化USB接口权限管理软件&#xff0c;适用于企业IT管理员、保密部门及个人办公用户&#xff0c;实现对U盘、移动硬盘、USB光驱等外接存储设备的…...

乐变热更新服务专项测评:破解更新痛点,赋能产品精品化运营

在移动互联网行业&#xff0c;应用与游戏的版本更新始终是开发与运营团队的核心难题&#xff1a;强制大版本更新易造成用户严重流失&#xff0c;非强制更新则会带来多版本并行管理的巨大压力&#xff0c;更新周期长、效率低的痛点长期制约着产品运营。本次测评基于乐变官方发布…...

可道云私有化部署优势解析

可道云为何适合中小型企业及大规模组织进行私有化部署可道云作为一款优秀的企业级私有云盘解决方案&#xff0c;其独特的架构设计和功能特性使其能够同时满足中小型企业和大型组织的多样化需求。以下从多个维度详细分析其适配性。一、灵活的授权模式满足不同规模需求用户规模的…...

Vue中的MVC、MVP、MVVM有什么区别?一篇搞懂前端架构模式

在Vue开发中&#xff0c;我们经常听到MVC、MVP、MVVM这三个架构模式的说法&#xff0c;尤其是MVVM&#xff0c;作为Vue的核心架构&#xff0c;几乎是每个前端开发者必备的知识点。但很多人容易混淆这三者的概念&#xff0c;不清楚它们之间的核心差异&#xff0c;以及为什么Vue会…...

IFN-γ抗体能否破解肿瘤微环境中的剂量悖论?

一、IFN-γ在肿瘤免疫中扮演什么角色&#xff1f;干扰素-γ&#xff08;IFN-γ&#xff09;是一种主要由活化T细胞、自然杀伤细胞及自然杀伤T细胞产生的炎性细胞因子&#xff0c;传统上被认为在抗肿瘤免疫中发挥核心作用。其通过与细胞表面异源二聚体受体&#xff08;IFNGR1/IF…...

告别代码臃肿!Java 基础语法 02:方法定义、调用与实战

&#x1f44b; 你好呀&#xff01;我是正在学习 AI 智能应用开发的学习者。 上一篇我们搞定了 变量、数据类型、运算符&#xff0c;已经能写简单的运算逻辑。 但代码一多就会变得又长又乱、重复度极高 —— 这时候就必须学会Java 方法&#xff01; 方法是 Java 最基础、最重要的…...

ros2简单的案例,一个节点采集图片,一个节点推理

先说一下为什么要学ros2&#xff0c;&#xff1a;首先他的通信非常快,而且可以多语言编程。比如说&#xff0c;如果要采集一张&#xff0c;然后多个模型推理&#xff0c;然后结果汇总&#xff0c;如果就单纯的用python的多线程&#xff0c;多进程&#xff0c;不仅速度慢&#x…...

QClaw 使用教程 亲测体验:腾讯亲儿子版“龙虾”,微信一句话就能远程操控电脑!(附完整截图+0门槛部署)

大家好&#xff0c;我是 BUG猿&#xff0c;专注 AI 大模型本地部署、省钱白嫖、实用工具踩坑的程序员。最近腾讯电脑管家悄然放出了 QClaw&#xff08;官方定位&#xff1a;随时随地&#xff0c;微信一下&#xff0c;QClaw帮你高效干活&#xff09;&#xff0c;直接把火爆的开源…...

2026年必看!水浸传感器选购避坑指南,守护家庭安全

在2026年的今天&#xff0c;随着智能家居与工业自动化程度的不断加深&#xff0c;水浸传感器作为预防泄漏风险的第一道防线&#xff0c;其重要性日益凸显。无论是家庭中的地下室、厨房、阳台&#xff0c;还是数据中心、精密厂房等关键设施&#xff0c;一次未被及时发现的水浸事…...

一个例子快速搞懂净现值(NPV)

场景你现在要开一个小项目&#xff1a;今天立刻投&#xff1a;1000 元1 年后能收回&#xff1a;1200 元银行利率&#xff08;折现率&#xff09;&#xff1a;5%问&#xff1a;这个项目到底赚不赚&#xff1f;值不值得做&#xff1f;我们来算 净现值 NPV。第一步&#xff1a;先算…...

win11配置java环境变量_主要是位置不好找啊_win7_win10好找---AI大模型应用探索0006

在设定画面&#xff0c;设置画面找到&#xff0c;这个可以看到有个系统详细设置可以看到有个环境变量&#xff0c;打开然后找到系统变量&#xff0c;然后&#xff1a;配置 CLASSPATH%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar然后再去配置&#xff1a;JAVA_HOMED:\2026…...

毕设程序java在线作业管理系统 基于Java的智能化作业提交与评阅平台 Java驱动的数字化课业管理与交互系统

毕设程序java在线作业管理系统6u09wm4d &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。随着教育信息化进程的不断深入&#xff0c;传统纸质作业管理模式已难以满足现代教学的多元…...

Day50:2026年3月18日打卡

一、上机打卡1.1 回形取数1.1.1 题目回形取数就是沿矩阵的边取数&#xff0c;若当前方向上无数可取或已经取过&#xff0c;则左转90度。一开始位于矩阵左上角&#xff0c;方向向下。输入说明&#xff1a;输入第一行是两个不超过200的正整数m, n&#xff0c;表示矩阵的行和列。接…...

K6性能测试及生成Html压测报告

一、引言&#xff1a; k6是一款开源负载测试工具&#xff0c;由Grafana Labs开发维护&#xff0c;专注于现代云环境和微服务架构 的高并发压测。它采用Go语言编写&#xff0c;使用JavaScript(ES6)作为脚本语言。还提到它特别适合CI/CD集成和自动化性能测试。 二、下载安装&am…...

低空运行技术研究报告

检索日期&#xff1a;2026-03-18 检索范围&#xff1a;SCI/EI/中文核心期刊/行业报告/预印本【研究进展】 一、代表性最新研究成果 1. 《A Survey of Security Challenges and Solutions for UAS Traffic Management (UTM) and small Unmanned Aerial Systems (sUAS)》 来源&am…...

面试必杀技:彻底搞懂 JVM 内存模型与区域划分(上篇)

在 Java 面试中&#xff0c;JVM&#xff08;Java 虚拟机&#xff09;是区分中高级开发者的分水岭。很多同学对 JVM 感到恐惧&#xff0c;觉得它只是一堆干巴巴的概念。其实&#xff0c;只要把它当成一个“虚拟的操作系统”&#xff0c;一切就豁然开朗了。 本系列将分为上、中、…...

从“亡羊补牢”到“规则先行”:金仓数据库的主动防御之道

在数字化转型的浪潮中&#xff0c;数据已成为企业的核心资产。然而&#xff0c;SQL注入攻击如同潜伏在阴影中的“不速之客”&#xff0c;时刻威胁着数据库的安全。即使开发团队严守预编译、输入过滤等防线&#xff0c;遗留代码、第三方组件的漏洞或人为疏忽仍可能给攻击者可乘之…...

四六级 | 2026年英语四六级视频课程

2026上半年四六级笔试/口试时间已定 &#x1f4cc; 考试时间 ▪ 笔试&#xff1a;6月13日 ▪ 口试&#xff1a;5月23日—5月24日 &#x1f4cc; 准考证打印 ▪ 口试准考证&#xff1a;5月19日 9:00起 ▪ 笔试准考证&#xff1a;6月5日 9:00起 四六级 | 2026年英语四六级视…...

OpenClaw Windows 10 WSL2 安装与配置指南+飞书接入(使用腾讯云Coding Plan)

文章目录基础环境第一阶段&#xff1a;安装 WSL2 环境1.1 开启 WSL21.2 迁移 WSL2 到非 C 盘&#xff08;推荐&#xff09;1.3 启用 systemd1.4 WSL 固定 DNS1.4.1 关闭 WSL 自动生成 DNS1.4.2 删除 systemd 生成的 resolv.conf1.4.3 创建新的静态 DNS 文件1.4.4 重启 WSL1.4.5…...

20260318_203310_AI大模型之RAG(向量库milvus实现)

介绍概念&#xff1a;RAG 检索增强生成Retrieval-Augmented Generation 打个比方 普通 AI&#xff1a;像闭卷考试&#xff0c;只会脑子里记的东西&#xff0c;容易记错、过时。 RAG AI&#xff1a;像开卷考试&#xff0c;先去翻你给的课本 / 文档&#xff0c;找到相关内容&am…...

固定资产清查别敷衍!账实对不上、资产流失,全是清查没做细

说起企业资产管理&#xff0c;很多人盯着折旧核算&#xff0c;却忽略了最基础的固定资产清查。这项工作看似繁琐&#xff0c;却是堵住资产流失、校准财务数据、规避税务与内控风险的关键一步&#xff0c;不管是中小企业还是大型公司&#xff0c;定期做规范清查&#xff0c;才能…...

选艺术字体AI工具这件事,别只盯出图快慢

在日常门店运营中&#xff0c;活动海报的艺术字体设计需要兼顾效率和后续修改空间。最近一次促销活动&#xff0c;首版物料我选择了千图的AI艺术字体工具&#xff0c;主要看重其AI海报可编辑和同款生成功能——能够让AI先产出风格方向&#xff0c;再进一步用其抠图、放大、消除…...

Edge浏览器 about:blank 问题修复

打开新标签出现 about:blank 空页面 修改-> 修复 Get-AppxPackage MicrosoftEdge | Foreach {Add-AppxPackage -DisableDevelopmentMode -Register "(_.InstallLocation)\AppXManifest.xml"}命令含义解析 这段PowerShell命令的核心作用是重新注册/修复微软Edge…...

根据ai创建校园管理系统——MySQL数据库设计与建立

native效果展示一.DDL语句-- -- 校园二手交易系统 - DDL数据定义语句 -- -- 1. 初始化设置 SET FOREIGN_KEY_CHECKS 0; -- 临时关闭外键检查&#xff0c;避免删表报错 SET NAMES utf8mb4;-- 2. 创建并使用数据库 CREATE DATABASE IF NOT EXISTS campus_second_hand_trade D…...

应用数学新时代的到来

以下内容转载自微信公众号“数学家”&#xff0c;仅作分享 原文链接&#xff1a;https://mp.weixin.qq.com/s/qbnHosCL13TaPSQ9DRih5w 鄂维南&#xff0c;1963年9月生于江苏省靖江市&#xff0c;数学家&#xff0c;中国科学院院士&#xff0c;北京大学、普林斯顿大学教授、北京…...

把AIGC率降到个位数有多爽?2026十款主流免费降AI工具天花板实测

自从2024年各大高校引入AI检测系统后&#xff0c;无数学生陷入了"AI降AI"的死循环&#xff1a;用AI写论文效率高&#xff0c;但查出来就完蛋&#xff1b;手写太慢&#xff0c;赶不上ddl。于是&#xff0c;降低ai率成了比查重更棘手的难题。今天这篇文章&#xff0c;我…...

第6篇:中文语言 学会华夏本源语言能做什么?

第6篇&#xff1a;学会华夏本源语言能做什么&#xff1f; 作者&#xff1a; 大号&#xff1a;华夏之光永存&#xff08;道级解读&#xff09; 小号&#xff1a;华夏之光永存小号&#xff08;术级解读&#xff09; 核心简介&#xff1a; 道&#xff1a;领域永恒不变的本质规律…...

HTML学习日记——DAY01(基本标签)

今天我正式步入web开发中的html的学习了&#xff0c;今天主要针对HTML的基本标签展开了学习&#xff1a;1.HTML初始的一个标签组成&#xff1a;<!--声明当前文档的类型是html--> <!DOCTYPE html> <!--设置网页语言--> <html lang"en"> <!…...