初识 MQ

本文探讨了微服务中同步通讯的问题,包括耦合度高、性能下降和级联失败等,并对比了异步调用的优势,如服务解耦、性能提升和流量削峰。同时,介绍了MQ(消息队列)在异步通信中的作用,作为事件驱动架构中的Broker,用于解耦服务并提高系统稳定性。
摘要由CSDN通过智能技术生成

一、同步通讯和异步通讯

在这里插入图片描述

1. 同步调用的问题及优点

微服务间基于Feign的调用就属于同步方式,存在一些问题。
在这里插入图片描述

  1. 耦合度高
    每次加入新的需求,都要修改原来的代码
  2. 性能下降
    调用者需要等待服务提供者响应,如果调用链过长则响应时间等于每次调用的时间之和。
  3. 资源浪费
    调用链中的每个服务在等待响应过程中,不能释放请求占用的资源,高并发场景下会极度浪费系统资源
  4. 级联失败
    如果服务提供者出现问题,所有调用方都会跟着出问题,如同多米诺骨牌一样,迅速导致整个微服务群故障
  5. 优点
    时效性较强,可以立即得到结果

2.异步调用

异步调用常见实现就是事件驱动模式

  1. 优势一:服务解耦
    在这里插入图片描述
  2. 优势二:性能提升,吞吐量提高
    在这里插入图片描述
  3. 优势三:服务没有强依赖,不担心级联失败问题
    在这里插入图片描述
  4. 优势四:流量削峰
    在这里插入图片描述
异步总结
  1. 异步通信的优点:
    耦合度低
    吞吐量提升
    故障隔离
    流量削峰
  2. 异步通信的缺点:
    依赖于Broker的可靠性、安全性、吞吐能力
    架构复杂了,业务没有明显的流程线,不好追踪管理

二、什么是MQ

MQ (MessageQueue),中文是消息队列,字面来看就是存放消息的队列。也就是事件驱动架构中的Broker。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值