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到了交换机
相关推荐
凌乱的豆包11 小时前
Spring Cloud Alibaba Nacos 服务注册发现和分布式配置中心
分布式
独隅13 小时前
PyTorch 分布式训练完整指南:策略、实现与模型选型
人工智能·pytorch·分布式
架构师老Y14 小时前
011、消息队列应用:RabbitMQ、Kafka与Celery
python·架构·kafka·rabbitmq·ruby
墨北小七16 小时前
小说大模型的分布式训练——张量并行架构设计与实现
分布式
豆豆17 小时前
政务服务平台站群一体化解决方案
大数据·分布式·微服务·cms·政务·网站管理系统·站群cms
昵称暂无117 小时前
分布式事务难题:Seata框架在微服务中的落地实践
分布式·微服务·架构
都说名字长不会被发现18 小时前
分布式场景下的数据竞争问题与解决方案
分布式·乐观锁·悲观锁·redission·redis 分布式锁·数据版本
甘露s18 小时前
分布式与可重入性的一些问题
分布式
juniperhan18 小时前
Flink 系列第 3 篇:核心概念精讲|分布式缓存 + 重启策略 + 并行度 底层原理 + 代码实战 + 生产规范
大数据·分布式·缓存·flink
想你依然心痛18 小时前
HarmonyOS 5.0 IoT开发实战:构建分布式智能设备控制中枢与边缘计算网关
分布式·物联网·harmonyos