MQ异步通讯

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工作队列

  1. 多个消费者绑定到一个队列,消息只能被消费者处理一次。
  2. 消费预处理限制,修改application.yml,设置preFretch这个值,可以控制预处理消息的上线:
spring.rabbitmq.listener.simple.prefretch = 1 #每次只处理一个消息,处理完成获取下一个消息

2.发布、订阅模型

  1. 发布订阅模式之前案例的区别就是允许将同意消息发送到多个消费者。实现方式加入exchange(交换机)。
  2. 常见的交换机
    • Fanout:广播
    • Direct:路由
    • Topic:话题
  3. FanoutExchange的使用
    在这里插入图片描述4. DirectExchange的使用
    在这里插入图片描述
    5.TopicExchange的使用
    ![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/8917c45a9a174633b174e6bc709dbdcd.png

2.SpringAMQP的消息转换器

在这里插入图片描述

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对接应用同步接口和MQ异步通讯的代码设计可以采用以下步骤: 1. 定义消息队列的生产者和消费者,生产者将消息发送到消息队列中,消费者从消息队列中获取消息并进行处理。 2. 在应用程序中,定义同步接口和异步通讯接口,同步接口直接调用业务逻辑处理,异步通讯接口将消息发送到消息队列中,由消费者进行处理。 3. 在同步接口中,可以使用消息队列的同步调用方式,将消息发送到消息队列中,等待消费者处理完成后返回结果。 4. 在异步通讯接口中,将消息发送到消息队列中,不需要等待消费者处理完成,可以立即返回结果。 5. 在消费者中,根据消息类型进行不同的业务处理,处理完成后将结果返回给生产者。 6. 在生产者中,根据消费者返回的结果,返回给调用方。 以下是一个简单的示例代码: ```python # 定义消息队列的生产者和消费者 class MQProducer: def send(self, message): # 将消息发送到消息队列中 pass class MQConsumer: def consume(self, message): # 根据消息类型进行不同的业务处理 pass # 定义同步接口和异步通讯接口 class SyncInterface: def handle(self, message): # 直接调用业务逻辑处理 pass class AsyncInterface: def handle(self, message): # 将消息发送到消息队列中 MQProducer.send(message) # 立即返回结果 return "success" # 在消费者中处理消息 class MQConsumer: def consume(self, message): if message.type == "sync": # 同步调用方式,等待消费者处理完成后返回结果 result = SyncInterface.handle(message) MQProducer.send(result) elif message.type == "async": # 异步通讯方式,不需要等待消费者处理完成 AsyncInterface.handle(message) # 在生产者中处理结果 class MQProducer: def send(self, message): MQConsumer.consume(message) # 根据消费者返回的结果,返回给调用方 return result ``` 注意:以上代码仅为示例,实际应用中需要根据具体情况进行修改和完善。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值