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到了交换机
相关推荐
深蓝电商API23 分钟前
Scrapy+Rredis实现分布式爬虫入门与优化
分布式·爬虫·scrapy
回家路上绕了弯2 小时前
定期归档历史数据实战指南:从方案设计到落地优化
分布式·后端
爱琴孩2 小时前
RabbitMQ 消息消费模式深度解析
rabbitmq·消息重复消费
rchmin3 小时前
Distro与Raft协议对比分析
分布式·cap
小辉笔记3 小时前
kafka原理总结
分布式·kafka
实战项目3 小时前
分布式协作入侵检测系统的报警信息管理
分布式
利刃大大4 小时前
【RabbitMQ】Simple模式 && 工作队列 && 发布/订阅模式 && 路由模式 && 通配符模式 && RPC模式 && 发布确认机制
rpc·消息队列·rabbitmq·队列
无心水6 小时前
【分布式利器:腾讯TSF】10、TSF故障排查与架构评审实战:Java架构师从救火到防火的生产哲学
java·人工智能·分布式·架构·限流·分布式利器·腾讯tsf
小北方城市网17 小时前
分布式锁实战指南:从选型到落地,避开 90% 的坑
java·数据库·redis·分布式·python·缓存
范桂飓19 小时前
大模型分布式训练框架 Megatron-LM
人工智能·分布式