15、RabbitMQ

1、微服务之间是怎么交互的?

复制代码
1) 同步 使用OpenFeign 2、异步 使用MQ 需要获取返回值时只能用OpenFeign 

2、为什么要用MQ

复制代码
1)异步,可以提高页面响应速度 2)流量削峰填谷 3、解耦

3、详细说一下MQ是怎么用的?

复制代码
消息发送时使用 RabbitTemple的一个发送方法,消息消费者 方法上添加一个@RabbitListener(指定消费的队列) 注意,消息发送时发送到交换机中,然后再路由到队列中,路由时还设置可一个key

4、消息丢失怎么办(怎么防止消息丢失|怎么保证消息的可靠性?|使用MQ的时候有没有可能出现什么问题)

复制代码
发送方: 要开启确认机制,设置两个回调方法 一个是用来判断消息是否到达交换机 另一个是用来判断消息是否到达队列 MQ本身: 交换机、队列、消息都持久化到磁盘上 消费方:也需要开启确认机制,设置重试次数,重试次数到达上限后,会把消息转到一个专门存放错误消息的队列 

5、消息堆积怎么办?

复制代码
发送方瞬间并发量大、消费者效率低都会导致消息堆积 解决的方案:1、多加几个消费者 2、开启多线程 3、使用惰性队列(好处是消息直接放到磁盘)

6、怎么保证消息的幂等性?

复制代码
方案一:通用的 每一条消息都生成一个唯一的id,与消息一起投递给消费者。 消费者接收到消息后处理自己的业务,业务处理成功后将消息ID保存到Redis数据库 如果下次又收到相同消息,去Redis查询判断是否存在,存在则为重复消息放弃处理。 方案二: 结合着自己的业务 更新时:多带一个条件 新增时:先查询再新增

7、什么死信?(死信队列、死信交换机)

复制代码
消息超时未被消费的消息就成为了死信 应用场景:延迟消息

8、延迟消息怎么做?

复制代码
RabbitMQ提供一个专门用来做延迟消息的插件 创建交换机的时候需要声明是一个延迟交换机,发送消息时需要指定延迟的时间

9、在项目中你们使用的是MQ的哪种模式?

复制代码
direct topic 消息发送时携带了一个key到了交换机
相关推荐
少许极端4 小时前
消息队列-RabbitMQ(1)
分布式·消息队列·rabbitmq
若水不如远方5 小时前
分布式一致性(七):架构角度 —— 分布式共识系统的选型指南
分布式·后端
&&月弥6 小时前
三大开源消息队列(Kafka、RabbitMQ、RocketMQ)使用教程
kafka·开源·rabbitmq
Darkdreams7 小时前
分布式监控Skywalking安装及使用教程(保姆级教程)
分布式·skywalking
深蓝电商API16 小时前
分布式事务在跨境交易中的解决方案
分布式·跨境电商·代购系统·反向海淘·代购平台·跨境代购
我真会写代码20 小时前
从入门到精通:Kafka核心原理与实战避坑指南
分布式·缓存·kafka
黄俊懿1 天前
【架构师从入门到进阶】第二章:系统衡量指标——第一节:伸缩性、扩展性、安全性
分布式·后端·中间件·架构·系统架构·架构设计
一叶飘零_sweeeet1 天前
击穿 Kafka 高可用核心:分区副本、ISR 机制与底层原理全链路拆解
分布式·架构·kafka
007张三丰1 天前
常用缓存技术全方位解析:从本地缓存到分布式缓存
分布式·缓存
tianyuanwo1 天前
Koji 分布式编译调度机制深度解析:多架构异构节点的资源优化方案
分布式·架构