MQ学习前篇
文章目录
- MQ学习前篇
- 1、同步和异步通讯
- 1.1、同步通讯和异步通讯
- 1.2、同步调用存在的问题
- 1.3、异步调用方案
- 1.4、异步通信的缺点
1、同步和异步通讯
学习mq之前,就要先知道同步通讯和异步通讯的区别。
1.1、同步通讯和异步通讯
- 同步通讯就像是打电话,就如上面的图片一样,一次只能拨打一个人的电话,否则就是占线的状态。
- 异步通讯就好比你同时可以接受微信多个用户的消息,就算你人不在线也会有消息的内容。
1.2、同步调用存在的问题
微服务间基于Feign的调用就属于同步方式,存在一些问题。
-
耦合度高
每次加入新的需求,都要修改原来的代码。
-
性能下降
调用者需要等待服务提供者响应,如果调用链过长则响应时间等于每次调用的时间之和。
-
资源浪费
调用链中的每个服务在等待响应过程中,不能释放请求占用的资源,高并发场景下会极度浪费系统资源。
-
级联失败
如果服务提供者出现问题,所有调用方都会跟着出问题,如同多米诺骨牌一样,迅速导致整个微服务群故障。
1.3、异步调用方案
异步调用常见实现就是事件驱动模式
可以解决多个问题:
优势一:服务解耦
优势二:性能提升,吞吐量提高
优势三:服务没有强依赖,不担心级联失败问题
优势四:流量削峰(将待处理的消息存在消息队列中,一个一个进行处理)
1.4、异步通信的缺点
-
依赖于Broker的可靠性、安全性、吞吐能力
-
架构复杂了,业务没有明显的流程线,不好追踪管理
事实上,我们大多数情况都会使用同步通信,因为大多数情况下对并发的要求不是很高,要求较高的是时效性。
而异步通通信就是上述的那些概念:并发,解耦等。
下期我会讲解:RabbitMQ快速入门