聊聊RabbitMQ

RabbitMQ是一个开源的消息中间件

如果没有RabbitMQ,系统A直接把数据传给系统B,这样当B忙不过来或者挂了的时候,A就会卡死或者造成数据丢失。

但是,如果有了RabbitMQ,系统A可以把数据传给RabbitMQ,而RabbitMQ则负责把数据暂存起来,再按照系统B的处理能力,稳稳地传送给B。

RabbitMQ主要有3大应用场景:

1.比如在实现用户注册功能时,通过引入RabbitMQ进行异步处理,可以提升响应的速度:

没有引入RabbitMQ时,在注册完之后,需要同步地发邮件和短信,这样用户可能需要等几秒钟才能看到"注册成功"。

引入RabbitMQ之后,把注册的信息写入数据库之后,可以直接把"发送邮件"和"发送短信"这两个任务扔给RabbitMQ,这样就能够立刻给用户返回"注册成功"。

2.我们平常网购的时候,应该也会注意到,买东西的次数多了,某宝或者某东、某多的积分也会相应增加。

这也就是下单场景的积分累加。

想象一下如果订单系统直接调用积分接口,一旦积分系统挂了,那订单也下不了了。

有个大佬说过这样一句话:

没有什么是加一层中间层不能解决的,如果有,那就再加一层。

所以,中间加个RabbitMQ,这样订单系统只需要把"我要下单"的消息发送给RabbitMQ,而积分系统什么时候恢复那就什么时候再去取消息,从而累加积分。

通过这样引入RabbitMQ,可以实现应用之间的解耦,从而降低系统的依赖。

3.在双十一的秒杀场景下,通常会有几百上千万的请求在一瞬间涌进来,这个时候数据库可能就直接崩了。

通过引入RabbitMQ,先把请求全部扔进RabbitMQ排队,后台系统再按照自己的节奏从RabbitMQ中拉取请求进行处理,从而实现流量削峰,保护数据库的作用。

相关推荐
JLWcai202510094 小时前
铸造领域树脂砂轮|金利威多场景解决方案,20 + 配方覆盖全需求
mongodb·zookeeper·eureka·spark·rabbitmq·memcached·storm
风吹夏回8 小时前
RabbitMQ 核心术语 + Python pika 方法完整讲解
分布式·python·rabbitmq
风吹夏回8 小时前
RabbitMQ 三种模式入门:HelloWorld、WorkQueue、PubSub
分布式·rabbitmq·ruby
霸道流氓气质9 小时前
分布式追踪与 RequestId 传播完全指南
分布式
cheems95279 小时前
[RabbitMQ高级特性] 消息确认机制:从 Ready / Unacked 到 basicAck、basicReject、basicNack 的底层拆解
分布式·rabbitmq·ruby
枫华落尽9 小时前
【Hadoop01-完全分布式运行模式】
分布式
隔壁阿布都10 小时前
ShedLock 分布式定时任务锁框架介绍
spring boot·分布式
文艺倾年10 小时前
【强化学习】数学推导专题,20W字总结(十五)
人工智能·分布式·大模型·强化学习·vibecoding
ACP广源盛1392462567310 小时前
GSV9001S@ACP#1080P 级视频处理芯片,物理 AI 普及终端的高性价比选择
大数据·人工智能·分布式·嵌入式硬件·spark
guslegend10 小时前
第1章:初始Kafka
分布式·kafka