【图解RabbitMQ-1】图解消息队列是什么玩意儿?它的应用场景有哪些?

简介: 【图解RabbitMQ-1】图解消息队列是什么玩意儿?它的应用场景有哪些?

专栏推荐


  • 专门为Redis入门打造的专栏,包含Redis基础知识、基础命令、五大数据类型实战场景、key删除策略、内存淘汰机制、持久化机制、哨兵模式、主从复制、分布式锁等等内容。链接>>>>>>>>>《Redis从头学》
  • SpringBoot实战相关专栏,包含SpringBoot过滤器、拦截器、AOP实现日志、整合Freemaker、整合Redis等等实战相关内容,多篇文章登入全站热榜、领域热榜、被技术社区收录。链接>>>>>>《SpringBoot实战》

🌟什么是消息队列


以下解释来源于百度百科:


“消息队列”是在消息的传输过程中保存消息的容器。


个人理解:


消息队列用来应用程序之间的消息传递。


图解:

ecdd55994a36258fa0c3269c5ecc5848_46a66ef9e5264ed98af31d6d29b71c1c.png


🌟应用场景


消息队列作为消息中间件,可以用来解耦、异步、削峰。


解耦:生产者和消费者之间通过队列进行通信,降低系统间的耦合性。

异步:生产者发送消息后,仍旧可以执行其他任务,无需等待当前任务的执行状态。

削峰:消费者能力不足以跟上生产者的速度时,消息队列可以缓冲消息。


解耦

举例说明


比如说电商系统中,在下单系统与物流系统中引入消息队列MQ。下单系统将订单消息存入消息队列,物流系统负责监听消息队列得到商品订单消息。


传统模式:物流系统调用下单系统中的订单信息接口,假如下单系统故障则会导致发货失败。

be72cdc7c72feb40331cee7375b67aec_005d3fe097f14147b4d4900cd59beb33.png


MQ模式:下单系统无法访问时,物流系统可以监听队列中的订单消息。下单系统生产消息到队列中,仍可以执行其他任务。

14868ae18e0171be21e83b70f183b674_c9e136c64a3e428ba8d7e13903b7795b.png


异步

举例说明


比如说系统注册功能中,在用户注册时对用户异步发送注册邮件。


传统模式串行模式:在用户注册时,注册成功后将信息写入数据库,并对用户发送注册成功的邮件。响应总时间为60+70+70=200ms。

319e96414b4ae5e9819314041780827a_23b0678b0901454b8fc62f5bb13217de.png


传统模式并行模式:在用户注册时,注册成功将信息写入数据库。发送邮件和发送短信并行执行。响应总时间为60+70=130ms。

e325913faa683b7bf47e4526598c1b74_a6311168036546c5b6b2950cfb82d5cc.png


消息队列模式:在用户注册时,注册成功将信息写入数据库。发送邮件和发送短信异步执行发送到消息队列。响应总时间为60+30=90ms。

c92ab8215919ad6e672dc7a54730b0e4_adaacc94d7e54793a6dc0439aa9fb151.png


削峰

举例说明:


大量用户发送请求,进行秒杀活动时。


传统模式:大量用户请求超过服务器请求负荷。

faf23ee61edf915163c15a795458fe0b_914613bd0216451c802e162daaf44937.png

消息队列模式:服务器根据相关规则去消息队列读取相关请求。

269bbe3cf57e439ec068c5e7c4526463_8189582bc80c448c958e4e695032e2b9.png


🌟劣势分析


虽然上述两个小节对消息队列是什么以及应用场景有哪些?作出了具体解释并加以配图。但是它有什么缺点呢?


  1. 系统复杂性:引入消息队列会使系统更加的复杂,需要考虑各个组件间产生的影响
  2. 消息重复消费、丢失风险:需要保证消息的可靠性投递以及避免消息的重复消费,造成业务出现问题。


🌟写在最后


有关于图解消息队列是什么玩意儿?它的应用场景有哪些?到此就结束了。感谢大家的阅读,希望大家在评论区对此部分内容散发讨论,便于学到更多的知识。


相关实践学习
快速体验阿里云云消息队列RocketMQ版
本实验将带您快速体验使用云消息队列RocketMQ版Serverless系列实例进行获取接入点、创建Topic、创建订阅组、收发消息、查看消息轨迹和仪表盘。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
11月前
|
消息中间件 数据管理 Serverless
阿里云消息队列 Apache RocketMQ 创新论文入选顶会 ACM FSE 2025
阿里云消息团队基于 Apache RocketMQ 构建 Serverless 消息系统,适配多种主流消息协议(如 RabbitMQ、MQTT 和 Kafka),成功解决了传统中间件在可伸缩性、成本及元数据管理等方面的难题,并据此实现 ApsaraMQ 全系列产品 Serverless 化,助力企业提效降本。
|
9月前
|
消息中间件 Java Kafka
消息队列比较:Spring 微服务中的 Kafka 与 RabbitMQ
本文深入解析了 Kafka 和 RabbitMQ 两大主流消息队列在 Spring 微服务中的应用与对比。内容涵盖消息队列的基本原理、Kafka 与 RabbitMQ 的核心概念、各自优势及典型用例,并结合 Spring 生态的集成方式,帮助开发者根据实际需求选择合适的消息中间件,提升系统解耦、可扩展性与可靠性。
639 1
消息队列比较:Spring 微服务中的 Kafka 与 RabbitMQ
|
消息中间件
【有奖体验】解锁轻量消息队列(原 MNS)作为云产品间消息通道的典型场景
快来解锁轻量消息队列(原 MNS)作为云产品间消息通道的典型场景,赢丰厚奖品!
250 80
|
消息中间件 JSON Java
开发者如何使用轻量消息队列MNS
【10月更文挑战第19天】开发者如何使用轻量消息队列MNS
1102 96
|
消息中间件 安全 Java
云消息队列RabbitMQ实践解决方案评测
一文带你详细了解云消息队列RabbitMQ实践的解决方案优与劣
562 117
|
消息中间件 存储 大数据
阿里云消息队列 Kafka 架构及典型应用场景
阿里云消息队列 Kafka 是一款基于 Apache Kafka 的分布式消息中间件,支持消息发布与订阅模型,满足微服务解耦、大数据处理及实时流数据分析需求。其通过存算分离架构优化成本与性能,提供基础版、标准版和专业版三种 Serverless 版本,分别适用于不同业务场景,最高 SLA 达 99.99%。阿里云 Kafka 还具备弹性扩容、多可用区部署、冷热数据缓存隔离等特性,并支持与 Flink、MaxCompute 等生态工具无缝集成,广泛应用于用户行为分析、数据入库等场景,显著提升数据处理效率与实时性。
|
消息中间件 人工智能 自然语言处理
基于 RocketMQ 事件驱动架构的 AI 应用实践
基于 RocketMQ 事件驱动架构的 AI 应用实践
561 2
|
消息中间件 存储 前端开发
MQ有什么应用场景
MQ有什么应用场景
|
消息中间件 存储 监控
说说MQ在你项目中的应用(一)
本文总结了消息队列(MQ)在项目中的应用,主要围绕异步处理、系统解耦和流量削峰三大功能展开。通过分析短信通知和业务日志两个典型场景,介绍了MQ的实现方式及其优势。短信通知中,MQ用于异步发送短信并处理状态更新;业务日志中,Kafka作为高吞吐量的消息系统,负责收集和传输系统及用户行为日志,确保数据的可靠性和高效处理。MQ不仅提高了系统的灵活性和响应速度,还提供了重试机制和状态追踪等功能,保障了业务的稳定运行。
530 7