同步通讯和异步通讯
同步通讯一次只能和一个对象交谈,而异步通讯可以同时和多个
简单理解一下同步传输 和 异步传输的定义
同步传输:以数据块为单位进行发送,每个数据块包含多个字符,每个字符5-8bit。每个数据块前面加上起始标志,后面加上结束标志。
异步传输:以字符为单位发送,一次传输一个字符,每个字符5- 8bit,字符前面有一个起始位,后面有1个或2个停止位。无字符发送时一直发送停止位。
1.同步通讯
同步调用的问题
微服务间基于Feign的调用就属于同步方式,存在一些问题
例如支付服务被调用的同时,就要同时调用订单服务和仓储服务。
在支付服务的同时,订单服务需要耗时,仓储服务也需要耗时,整个服务流程就很慢,所以这就是同步调用的问题
会有很多资源的浪费
总结:
同步调用的优点:
时效性较强,可以立即得到结果
同步调用的问题:
耦合度高
性能和吞吐能力下降
有额外的资源消耗
有级联失败问题
2.异步通讯
异步调用方案
异步调用常见实现就是世间驱动模式
优势一:服务解耦
支付服务完成后把事件交付给事件代理,让订单服务、仓储服务等订阅事件代理即可
优势二:性能提升,吞吐量提高
优势三:服务没有强依赖,不担心级联失败问题
即使一个服务挂掉也不影响支付服务的流程
优势四:流量削峰
Broker可以起到缓冲作用
总结:
异步通信的优点:
耦合度低
吞吐量提升
故障隔离
流量削峰
异步通信的缺点:·
依赖于Broker的可靠性、安全性、吞吐能力
架构复杂了,业务没有明显的流程线,不好追踪管理
3.MQ常见框架
什么是MQ
MQ(MessageQueue),中文是消息队列,字面来看就是存放消息的队列。也就是事件驱动架构中的Broker。