为什么要使用消息中间件?

49 篇文章 2 订阅
为什么要使用消息中间件?

也就是说使用了消息中间件有哪些优点呢?

在我看来,优点主要有三个

  • 解耦
  • 异步
  • 削峰
解耦

什么叫解耦,为什么要解耦。
比如用户要访问一个程序A,但是呢这个程序有比较重要的数据要同步给B,C,D三个工程。用户后面可能会通过那三个工程去查询这个数据,所以这个数据需要给他们。
举一个例子:用户在A工程进行了一系列操作,会产生一个操作轨迹。先点击了什么,停留了多长时间,然后又点击了什么,观看了什么东西。这在APP里面的操作记忆是很有用的。
如下图:
在这里插入图片描述
每次A工程都要给B、C、D工程推送数据,后面呢又来了一个E工程说我也要这个数据,麻烦你也给我推送一下吧。
这A工程的开发就有些烦了对不对,你们每来一个工程,我都要修改一次代码,那有一天突然不想要了,我还要修改代码。这时候就要想了,我可不可以放到一个地方,你们谁要了都可以来取,我也不管到底有几个人取,只开发一次就行了。那这个放数据的地方可以通过消息中间件来实现。
这时候就实现了解耦
在这里插入图片描述

异步

异步和解耦定义其实有些相似,还用上面的例子来说明,当用户访问A程序的时候,有一些操作需要B、C、D工程来实现,那么每次分别去访问的话,时间会特别长,对用户肯定不友好
在这里插入图片描述
这时候我们就要思考了,这三个步骤的总耗时如果1s,那怎么优化呢。把一些用户必须的数据放在A工程中立刻给用户返回,其他可以延后的数据呢,放到B、C、D三个工程中,后来再给用户看。这时候就使用到了消息中间件。当用户访问A工程的时候,通过消息中间件通知B、C、D三个工程。你们进行一下某某操作,这时候就实现了异步
在这里插入图片描述

削峰

想要知道削峰,就要先知道什么是峰值。
不论什么工程,只有是给用户使用的,肯定会有用户使用的高峰期和低谷期。比如美团一般肯定是中午和晚饭时候用户点外卖的多;淘宝呢肯定是双十一的下单了最多。我们出门旅游不也分淡季旺季么,那这个人多的旺季就对应了程序的高峰期,淡季就对应了低谷期。峰值时候用户访问量越大,那对于我们程序的性能要求就越高
这时候我们为了应对高峰期的用户访问量,把数据库的性能拉满,大内存大磁盘都搞上。但是高峰期满足了,低谷期呢,毕竟高峰期只是一会儿而已,比如高峰期访问量会达到5000/1s,但其他时间一般就是500/1s。那么必然会造成了资源的浪费。
这时候就要考虑削峰,在高峰期的时候将一些可以延后的请求存入消息中间件,让工程去慢慢处理。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

木小同

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值