一、同步通讯和异步通讯
1. 同步调用的问题及优点
微服务间基于Feign的调用就属于同步方式,存在一些问题。
- 耦合度高
每次加入新的需求,都要修改原来的代码 - 性能下降
调用者需要等待服务提供者响应,如果调用链过长则响应时间等于每次调用的时间之和。 - 资源浪费
调用链中的每个服务在等待响应过程中,不能释放请求占用的资源,高并发场景下会极度浪费系统资源 - 级联失败
如果服务提供者出现问题,所有调用方都会跟着出问题,如同多米诺骨牌一样,迅速导致整个微服务群故障 - 优点
时效性较强,可以立即得到结果
2.异步调用
异步调用常见实现就是事件驱动模式
- 优势一:服务解耦
- 优势二:性能提升,吞吐量提高
- 优势三:服务没有强依赖,不担心级联失败问题
- 优势四:流量削峰
异步总结
- 异步通信的优点:
耦合度低
吞吐量提升
故障隔离
流量削峰 - 异步通信的缺点:
依赖于Broker的可靠性、安全性、吞吐能力
架构复杂了,业务没有明显的流程线,不好追踪管理
二、什么是MQ
MQ (MessageQueue),中文是消息队列,字面来看就是存放消息的队列。也就是事件驱动架构中的Broker。