欢迎光临
05-RabbitMQ 面试题
   

05-RabbitMQ 面试题

目录

1.RabbitMQ-如何保证消息不丢失?

2.RabbitMQ消息的重复消费问题如何解决的?

3.RabbitMQ中死信交换机 ? (RabbitMQ延迟队列有了解过嘛)

4.RabbitMQ如果有100万消息堆积在MQ , 如何解决(消息堆积怎么解决)

5.RabbitMQ的高可用机制有了解过嘛


 

1.RabbitMQ-如何保证消息不丢失?

消息中间件的好处

  1. 提供了系统之间的异步调用,让服务与服务之间解耦
  2. 削峰、填谷

场景:

  1. 异步发送(验证码、短信、邮件…)
  2. MySQL和Redis , ES之间的数据同步
  3. 分布式事务
  4. 削峰填谷

05-RabbitMQ 面试题,第1张

消息发送者(publisher )把消息发送给交换机(exchange),由交换机路由到队列,最后由消费者(consumer)进行消费消息。

出现消息丢失的四种情况:

  1. 消息未到达交换机
  2. 消息未到达队列
  3. 队列中消息丢失
  4. 消费者未接收到消息

生产者确认机制(解决消息未到达交换机、消息未到达队列问题)

RabbitMQ提供了publisher confirm机制来避免消息发送到MQ过程中丢失。消息发送到MQ以后,会返回一个结果(ack)给发送者,表示消息是否处理成功

05-RabbitMQ 面试题,第2张

如果消息发送失败,有两种情况:

  1. 消息到达交换机失败(publisher-confirm nack)
  2. 交换机路由到队列失败(publisher-return ack)

消息失败之后如何处理呢?

  1. 回调方法即时重发(知道哪一个消息发送失败,可以再发)
  2. 记录日志(如果还是发送失败,可以记录日志,通过查看日志进行补偿)
  3. 保存到数据库然后定时重发,成功发送后即刻删除表中的数据 

如果重发失败了怎么办?

  1. 一般消息发送失败了,很大几率是服务提供者宕机了或者是MQ宕机了,这两者不可能一直处于宕机状态。
  2. 如果还是不能解决,需要人工来解决这些问题

消息已经正常发送到队列,但是MQ 宕机了,也会导致消息丢失,该怎么解决?

消息持久化(解决队列中消息丢失问题)
MQ默认是内存存储消息,开启持久化功能可以确保缓存在MQ中的消息不丢失。(MQ宕机或重启后,在内存中的消息肯定会丢失,需要持久化)
1.交换机持久化:

<
 
 木香花的品种与特点  风铃木适合哪里种  迷迭香泡水喝的禁忌  花店加盟哪个牌子比较好  关于樱花的文案  竹子的画法步骤 
打赏
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《05-RabbitMQ 面试题》
文章链接:https://goodmancom.com/wl/175729.html