初试 MQ

同步通讯和异步通讯

在这里插入图片描述
同步通讯一次只能和一个对象交谈,而异步通讯可以同时和多个

简单理解一下同步传输 和 异步传输的定义

同步传输:以数据块为单位进行发送,每个数据块包含多个字符,每个字符5-8bit。每个数据块前面加上起始标志,后面加上结束标志。
异步传输:以字符为单位发送,一次传输一个字符,每个字符5- 8bit,字符前面有一个起始位,后面有1个或2个停止位。无字符发送时一直发送停止位。

1.同步通讯

同步调用的问题

微服务间基于Feign的调用就属于同步方式,存在一些问题

在这里插入图片描述

例如支付服务被调用的同时,就要同时调用订单服务和仓储服务。
在这里插入图片描述
在支付服务的同时,订单服务需要耗时,仓储服务也需要耗时,整个服务流程就很慢,所以这就是同步调用的问题
会有很多资源的浪费

总结:
在这里插入图片描述

同步调用的优点:

时效性较强,可以立即得到结果

同步调用的问题:

耦合度高
性能和吞吐能力下降
有额外的资源消耗
有级联失败问题

2.异步通讯

异步调用方案

异步调用常见实现就是世间驱动模式

优势一:服务解耦

在这里插入图片描述
支付服务完成后把事件交付给事件代理,让订单服务、仓储服务等订阅事件代理即可

优势二:性能提升,吞吐量提高

在这里插入图片描述

优势三:服务没有强依赖,不担心级联失败问题

在这里插入图片描述
即使一个服务挂掉也不影响支付服务的流程

优势四:流量削峰

在这里插入图片描述

在这里插入图片描述

Broker可以起到缓冲作用

在这里插入图片描述

总结:

异步通信的优点:

耦合度低
吞吐量提升
故障隔离
流量削峰

异步通信的缺点:·

依赖于Broker的可靠性、安全性、吞吐能力
架构复杂了,业务没有明显的流程线,不好追踪管理

3.MQ常见框架

什么是MQ

MQ(MessageQueue),中文是消息队列,字面来看就是存放消息的队列。也就是事件驱动架构中的Broker。
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

阿岳316

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

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

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

打赏作者

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

抵扣说明:

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

余额充值