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

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 【图解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版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
3月前
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
96 6
|
1月前
|
消息中间件 存储 监控
说说MQ在你项目中的应用(一)
本文总结了消息队列(MQ)在项目中的应用,主要围绕异步处理、系统解耦和流量削峰三大功能展开。通过分析短信通知和业务日志两个典型场景,介绍了MQ的实现方式及其优势。短信通知中,MQ用于异步发送短信并处理状态更新;业务日志中,Kafka作为高吞吐量的消息系统,负责收集和传输系统及用户行为日志,确保数据的可靠性和高效处理。MQ不仅提高了系统的灵活性和响应速度,还提供了重试机制和状态追踪等功能,保障了业务的稳定运行。
73 6
|
2月前
|
消息中间件
【有奖体验】解锁轻量消息队列(原 MNS)作为云产品间消息通道的典型场景
快来解锁轻量消息队列(原 MNS)作为云产品间消息通道的典型场景,赢丰厚奖品!
|
1月前
|
消息中间件 存储 中间件
说说MQ在你项目中的应用(二)商品支付
本文总结了消息队列(MQ)在支付订单业务中的应用,重点分析了RabbitMQ的优势。通过异步处理、系统解耦和流量削峰等功能,RabbitMQ确保了支付流程的高效与稳定。具体场景包括用户下单、支付请求、商品生产和物流配送等环节。相比Kafka,RabbitMQ在低吞吐量、高实时性需求下表现更优,提供了更低延迟和更高的可靠性。
51 0
|
3月前
|
消息中间件 JSON Java
开发者如何使用轻量消息队列MNS
【10月更文挑战第19天】开发者如何使用轻量消息队列MNS
238 11
|
2月前
|
消息中间件 存储 Apache
探索 RocketMQ:企业级消息中间件的选择与应用
RocketMQ 是一个高性能、高可靠、可扩展的分布式消息中间件,它是由阿里巴巴开发并贡献给 Apache 软件基金会的一个开源项目。RocketMQ 主要用于处理大规模、高吞吐量、低延迟的消息传递,它是一个轻量级的、功能强大的消息队列系统,广泛应用于金融、电商、日志系统、数据分析等领域。
147 0
探索 RocketMQ:企业级消息中间件的选择与应用
|
3月前
|
消息中间件 安全 Java
云消息队列RabbitMQ实践解决方案评测
一文带你详细了解云消息队列RabbitMQ实践的解决方案优与劣
123 9
|
2月前
|
消息中间件 存储 Kafka
MQ 消息队列核心原理,12 条最全面总结!
本文总结了消息队列的12个核心原理,涵盖消息顺序性、ACK机制、持久化及高可用性等内容。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
|
3月前
|
消息中间件
解决方案 | 云消息队列RabbitMQ实践获奖名单公布!
云消息队列RabbitMQ实践获奖名单公布!
|
3月前
|
消息中间件 存储 弹性计算
云消息队列RabbitMQ实践
云消息队列RabbitMQ实践