【图解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
目录
相关文章
|
1月前
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
74 6
|
5天前
|
消息中间件
【有奖体验】解锁轻量消息队列(原 MNS)作为云产品间消息通道的典型场景
快来解锁轻量消息队列(原 MNS)作为云产品间消息通道的典型场景,赢丰厚奖品!
|
25天前
|
消息中间件 JSON Java
开发者如何使用轻量消息队列MNS
【10月更文挑战第19天】开发者如何使用轻量消息队列MNS
66 6
|
20天前
|
消息中间件 存储 Kafka
MQ 消息队列核心原理,12 条最全面总结!
本文总结了消息队列的12个核心原理,涵盖消息顺序性、ACK机制、持久化及高可用性等内容。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
|
23天前
|
消息中间件
解决方案 | 云消息队列RabbitMQ实践获奖名单公布!
云消息队列RabbitMQ实践获奖名单公布!
|
1月前
|
消息中间件 安全 Java
云消息队列RabbitMQ实践解决方案评测
一文带你详细了解云消息队列RabbitMQ实践的解决方案优与劣
67 6
|
1月前
|
消息中间件 存储 弹性计算
云消息队列RabbitMQ实践
云消息队列RabbitMQ实践
|
1月前
|
消息中间件 存储 监控
解决方案 | 云消息队列RabbitMQ实践
在实际业务中,网站因消息堆积和高流量脉冲导致系统故障。为解决这些问题,云消息队列 RabbitMQ 版提供高性能的消息处理和海量消息堆积能力,确保系统在流量高峰时仍能稳定运行。迁移前需进行技术能力和成本效益评估,包括功能、性能、限制值及费用等方面。迁移步骤包括元数据迁移、创建用户、网络打通和数据迁移。
64 4
|
2月前
|
消息中间件 弹性计算 运维
阿里云云消息队列RabbitMQ实践解决方案评测报告
阿里云云消息队列RabbitMQ实践解决方案评测报告
73 9
|
2月前
|
消息中间件 监控 数据处理
解决方案 | 云消息队列RabbitMQ实践
解决方案 | 云消息队列RabbitMQ实践
52 1