MQ异步通讯
文章目录
前言
同步调用问题,微服务之间基于Feign的调用就数据同步方式,存在的问题。
- 耦合度高:每次加入新请求,都要修改原来的代码
- 性能下降:调用者需要等待服务提供者响应,如果调用链过长则响应时间也会随之增加
- 浪费资源:调用链中的每个服务在等待响应中,不会释放资源,高并发环境下极度浪费资源
- 联级失败:如果服务提供者出现问题,所有的方法都会跟着出现问题
一、初始MQ
1.异步通讯的优缺点
异步通讯优点
- 耦合度低
- 吞吐量提升
- 故障隔离
- 流量削峰
异步通讯缺点 - 太过依赖于Broker的可靠性、安全性、吞吐量
- 架构复杂了,业务没有明显的流水线,不好追踪管理
2.什么是MQ
MQ(MessageQueue),中文是消息队列,也是时间驱动构架中的Broker
二、MQ入门
1.常用消息模型
- 基本消息队列(BasicQueue)
- 工作消息队列(WorkQueue)
- 发布订阅(Publish、Subscribe),根据交换机类型不同分为三种
- Fanout Exchange:广播
- Direct Exchange:路由
- Topic Exchange:主题
三、MQ实践
1.work queue工作队列
- 多个消费者绑定到一个队列,消息只能被消费者处理一次。
- 消费预处理限制,修改application.yml,设置preFretch这个值,可以控制预处理消息的上线:
spring.rabbitmq.listener.simple.prefretch = 1 #每次只处理一个消息,处理完成获取下一个消息
2.发布、订阅模型
- 发布订阅模式之前案例的区别就是允许将同意消息发送到多个消费者。实现方式加入exchange(交换机)。
- 常见的交换机
- Fanout:广播
- Direct:路由
- Topic:话题
- FanoutExchange的使用
4. DirectExchange的使用
5.TopicExchange的使用