面试八股——RabbitMQ

消息丢失问题

消息确认机制

生产者与MQ之间的消息确认:

当MQ成功接收消息后,会返回给生产者一个确认消息。如果在规定时间内生产者未收到确认消息,则任务消息发送失败。

MQ与消费者之间的消息确认:

当MQ成功接收消息后,会返回给MQ一个确认消息,MQ此时会将对应消息删除。如果在规定时间内MQ未收到确认消息,则任务消息发送失败。

补发机制

当确认消息丢失后,可通过补发机制重发消息:

通过回调方法即时完成重发。

将发送的消息记录于日志文件当中。然后进行重发。

持久化

MQ通过内存存储消息,如果系统突然断电会导致消息丢失。因此可使用持久化方法(交换机持久化、队列持久化、消息持久化):

重复消费问题

出现原因举例:在保证MQ消息不重复的情况下,消费者消费消息成功后,在给MQ发送消息确认的时候出现了网络异常(或者是服务中断),MQ没有接收到确认,此时MQ会补发一条消息,从而导致重复消费。

解决方法:

  1. 每条消息设置唯一id。消费者接收到消息时会校验id是否存在(是否已在数据库中),如果存在则不处理该条消息。

  2. 幂等方案。

死信交换机

死信交换机的定义:

  1. 消息被消费者拒绝
  1. 消息超过生存时间TTL:这个方法可实现超时队列。如订单支付,给订单消息创建TTL,如果超时,订单消息变为死信,订单失效。

3.队列满了,则处于对头的消息也可能成为死信。

消息堆积问题

问题描述:

解决方法:

扩大队列容积的办法------惰性队列(将队列中的消息存入磁盘而非内存):

相关推荐
专业抄代码选手38 分钟前
【Leetcode】1930. 长度为 3 的不同回文子序列
javascript·算法·面试
2501_941143731 小时前
分布式日志系统与可观测性在高并发互联网系统架构优化与实践分享
rabbitmq
debug骑士1 小时前
面向安全与高性能微服务的Rust异步架构设计与工程化实践经验分享探索研究
rabbitmq
程序员小远1 小时前
Appium-移动端自动测试框架详解
自动化测试·软件测试·python·测试工具·职场和发展·appium·测试用例
2501_941801762 小时前
人工智能与物联网:智能家居生态的崛起与未来
rabbitmq
2501_941143322 小时前
基于 Node.js 构建高并发实时 Web 应用与微服务系统的架构设计实践分享
rabbitmq
源码梦想家2 小时前
数字孪生应用深化背景下在珠海基于 Rust 构建城市级实时三维仿真平台的体系架构与工程实践研究
rabbitmq
2501_941877983 小时前
面向未来的高可用互联网系统智能架构构建弹性业务链优化研发效率提升企业数字化能力创新实践研究
rabbitmq
2501_941144423 小时前
分布式配置中心Nacos与Consul在高并发互联网系统优化实践经验分享
rabbitmq
拉不动的猪3 小时前
Vue 跨组件通信底层:provide/inject 原理与实战指南
前端·javascript·面试