首页 > 其他分享 >RabbitMQ面试题

RabbitMQ面试题

时间:2024-08-17 16:54:29浏览次数:8  
标签:面试题 队列 RabbitMQ 处理 MQ 消息 保证

一、RabbitMQ如何保证消息的可靠性

RabbiMQ如果想要保证消息的可靠性有几种方式可以实现:

1、消费端消息可靠性保证:

1).消息确认
在消费端可以设置手动ACK模式,为确保消息可靠性,手动确认消息是否被正常处理,若存在异常或者未运行,则消息超时后不会被删除,会被重新投递
2).死信队列
当消息不被正常使用时,可以设置过期时间或死信交换器将消息转入死信队列中,从而分析处理这些消息

2、生产端消息可靠性保证:

1).消息持久化
在发布消息时,可以将消息标记为持久化(persistent),这样消息就会被持久化存储到磁盘上面,即使RabbitMQ服务器重启,消息也不会丢失
2).消息确认机制
启用confirm模式,在消费者发布消息后,由RabbitMQ服务器确认,根据确认信号判断消息是否正常路由到队列中并采取相应的重试策略

二、 如何保证消息的幂等性?

1、MQ中出现幂等性问题的主要原因

(1)生产者重复生产
当网络发生故障时,生产者可能会多次发出相同的信号
(2)MQ重复发送消息给消费者
当消费者拉去信息后,由于网络或者服务器宕机的原因,MQ没有及时响应导致超时,MQ会认为第一次消费失败再去发送一次消息,导致发送消息重复

2、解决幂等性问题的办法

  1. 状态检查:
    在消息发送出去之前,检查数据库中的消息状态是非被处理,已被处理就忽略,没有被处理则发送并标记为已处理
  2. 唯一标识:
    给消息加上一个唯一标识符,可以根据这个标识来判断两次消息是否是同一条。

三、RabbitMQ中如何解决消息堆积问题

一般情况下消息堆积问题有三种解决方案:

  1. 增加更多消费者,提高消费能力
  2. 在消费者内开启线程池加快处理速度
  3. 最好的方法就是使用惰性队列,扩大队列容积
    惰性队列优点:
    基于磁盘存储,消息上限高,性能比较稳定
    但是由于是基于磁盘存储,受限于磁盘IO,时效会降低

四、如何保证消息有序性?

保证消息的有序性的办法:

  1. 单一队列:将消息都发送到一个队列里面,并确保消费者按顺序处理消息
  2. 分区排序:将消息按特定规则排序,并为每个分区维护一个队列,但不同的分区消息顺序无法保证
  3. 消息标识:给元素数据中添加序列号或者时间戳等标识,消费者处理消息时根据标记确保消息顺序
  4. 有序消息中间件:一些消息队列中间件提供了特定的功能来保证消息的有序性

标签:面试题,队列,RabbitMQ,处理,MQ,消息,保证
From: https://blog.csdn.net/qq_53098873/article/details/141199534

相关文章

  • RabbitMQ-记录一个问题及解决
    我在配置文件中写入了rabbitmq:host:127.0.0.1port:5672username:guestpassport:guestvirtualhost:/switchFlag:truepool_size:10然后希望实现一个监听器,所以加上了注解形式@RabbitListener(queues=CommonConstants.QUERE_NAME_NOTIFY),由于我工作......
  • Java后端面试题(mq相关)(day9)
    目录为什么用MQ?异步、削峰、解耦1.异步处理2.解耦3.削峰填谷Exchange类型什么是死信队列?如何保证消息的可靠性?RabbitMQ中如何解决消息堆积问题?RabbitMQ中如何保证消息有序性?如何防止消息重复消费?(如何保证消息幂等性)为什么用MQ?异步、削峰、解耦MQ(Message......
  • 后端实习面试题
    1.有没有用过分页?Mybatis-PageHelper2.如果你想实现分页这个功能,需要前端传递哪些参数?后端给前端返回哪些数据?前端传递以下参数给后端:pageNum:当前页码,表示要查询的是第几页的数据。pageSize:每页显示的数据条数,确定每页显示的数据量。其他查询条件:可选参数,如筛选条件......
  • 面试题:在Java中,JVM(Java虚拟机)的内存模型是如何设计的?请详细解释堆(Heap)、栈(Stack)、方法
    面试题:在Java中,JVM(Java虚拟机)的内存模型是如何设计的?请详细解释堆(Heap)、栈(Stack)、方法区(MethodArea)以及程序计数器(ProgramCounterRegister)的作用和它们之间的关系。更多答案在这里,手机或电脑浏览器就可以打开,面霸宝典【全拼音】.com这里可以优化简历,模拟面试,企业项......
  • 面试题:在Java中,线程之间的通信主要通过哪几种方式实现?并简述其中一种方式的基本工作原
    面试题:在Java中,线程之间的通信主要通过哪几种方式实现?并简述其中一种方式的基本工作原理。请注意,除了直接回答此问题外,我们还为您准备了更多深入的学习资源和面试技巧。想要了解更多关于Java线程通信、优化简历、模拟面试、企业项目源码、大厂高并发面试题、项目场景题、算法......
  • 面试题:在Java中,多线程编程是常见的并发处理方式。请简述Java中实现多线程的几种主要方
    面试题:在Java中,多线程编程是常见的并发处理方式。请简述Java中实现多线程的几种主要方式,并解释每种方式的基本思想。更多关于多线程编程的深入解析、面试技巧、以及实战项目源码,手机浏览器即可访问面霸宝典【全拼音】.com,这里不仅可以优化你的简历,还能进行模拟面试,获取最新最......
  • 面试题:在Java中,volatile 关键字的作用是什么?它与 synchronized 关键字在实现线程同步
    面试题:在Java中,volatile 关键字的作用是什么?它与 synchronized 关键字在实现线程同步方面有何不同?请深入探讨其背后的原理和应用场景。更多答案在这里,手机或电脑浏览器就可以打开, 面霸宝典【全 拼音】.com 这里可以优化简历,模拟面试,企业项目源码,最新最全大厂高并......
  • TypeScript 面试题汇总
    引言TypeScript是一种由微软开发的开源、跨平台的编程语言,它是JavaScript的超集,为JavaScript添加了静态类型系统和其他高级功能。随着TypeScript在前端开发领域的广泛应用,掌握TypeScript已经成为很多开发者必备的技能之一。本文将整理一系列常见的TypeScript面试题......
  • RabbitMQ的介绍
    一、什么是MQMQ(messagequeue),从字面意思上看就个FIFO先入先出的队列,只不过队列中存放的内容是message而已,它是一种具有接收数据、存储数据、发送数据等功能的技术服务。消息指的是两个应用间传递的数据。数据的类型有很多种形式,可能只包含文本字符串,也可能包含嵌入对象......
  • 文心快码Baidu Comate 帮你解大厂面试题:Java G1 GC中,region是什么意思?有哪些不同的reg
    ......