11.面试题——消息队列RabbitMQ
1.RabbitMQ是什么?特点是什么?
RabbitMQ是一种开源的消息队列中间件,用于在应用程序之间进行可靠的消息传递。它实现了AMQP(Advanced Message Queuing Protocol)协议,提供了强大的消息处理能力。RabbitMQ的主要特点包括:
- 可靠性:RabbitMQ使用可靠的消息传递机制,确保消息能够安全地传递和持久化存储。
- 灵活的路由:RabbitMQ提供了灵活的路由机制,可以根据消息的内容将消息路由到不同的队列。
- 消息确认:生产者可以选择等待消费者对消息进行确认,以确保消息被成功处理。
- 高可用性:RabbitMQ支持集群模式,可以提供高可用性和负载均衡。
- 扩展性:RabbitMQ可以根据需求进行水平扩展,以处理大量的消息流量。
2.RabbitMQ的核心组件有哪些?
- Producer(生产者):负责产生并发送消息到RabbitMQ的消息队列。
- Exchange(交换机):接收从生产者发送的消息,并根据一定的规则将消息路由到一个或多个队列中。
- Queue(队列):用于存储消息,等待消费者从中接收和处理消息。
- Binding(绑定):连接交换机和队列的规则,定义了消息从交换机到队列的路由规则。 Consumer(消费者):从队列中接收并处理消息。
3.RabbitMQ中的消息模型是什么?
RabbitMQ中的消息模型是基于发布/订阅模型。常见的消息模型包括:
- Point-to-Point(点对点)模型:生产者发送消息到队列,只有一个消费者从队列中接收并处理消息。
- Publish/Subscribe(发布/订阅)模型:生产者发送消息到交换机,交换机将消息广播到绑定的所有队列,每个队列都有一个消费者来接收并处理消息。
- Routing(路由)模型:生产者发送消息到交换机,并使用路由键(routing key)作为标识,交换机根据路由键将消息路由到指定的队列。
- Topics(主题)模型:生产者发送带有主题(topic)的消息到交换机,交换机根据主题将消息路由到符合指定主题规则的队列。
4.RabbitMQ中的生产者和消费者是如何通信的?
- 生产者连接到RabbitMQ服务器,并创建一个通道(channel)。
- 生产者声明一个队列,并将消息发送到队列中。
- 消费者连接到RabbitMQ服务器,并创建一个通道。
- 消费者订阅(或消费)特定队列中的消息。
- RabbitMQ将队列中的消息传递给消费者,消费者接收并处理消息。
5.RabbitMQ中的Exchange是什么?
Exchange(交换机)是RabbitMQ的重要组件,用于接收从生产者发送的消息,并根据一定的规则将消息路由到一个或多个队列中。
RabbitMQ提供了几种类型的Exchange,包括:
- Direct Exchange(直连交换机):根据消息的路由键(routing key)将消息路由到与之完全匹配的队列。 Fanout
- Exchange(扇形交换机):将消息广播到所有与该交换机绑定的队列,忽略路由键的匹配规则。 Topic
- Exchange(主题交换机):根据消息的主题(topic)与队列的绑定主题进行匹配,将消息路由到符合规则的队列。 Headers
- Exchange(头交换机):根据消息的头部属性进行匹配,将消息路由到符合规则的队列。
Exchange的类型决定了消息在交换机和队列之间的路由行为。生产者将消息发送到特定类型的交换机,然后交换机根据类型和规则将消息路由到一个或多个队列,最终由消费者进行消费。
6.RabbitMQ中的Queue是什么?
在RabbitMQ中,Queue(队列)是消息的缓冲区,用于存储待处理的消息。它是消息的终点,生产者将消息发送到队列中,而消费者从队列中接收并处理消息。队列采用先进先出(FIFO)的方式,确保消息按照发送顺序进行处理。
工作原理如下:
- 生产者将消息发送到队列中。
- 消费者连接到队列,并注册对队列中消息的监听。
- 当消息到达队列时,RabbitMQ将消息存储在队列中,并将其传递给一个或多个消费者。
- 消费者从队列中接收并处理消息,消息在队列中的顺序得到保持。
队列在RabbitMQ中具有持久性和非持久性两种类型。持久性队列在服务器重启后仍然存在,而非持久性队列则在服务器重启时被删除。
7.RabbitMQ中的绑定(Binding)是什么?
在RabbitMQ中,绑定(Binding)是连接交换机和队列的规则。它定义了消息从交换机到队列的路由规则。
绑定的作用是将交换机和队列关联起来,使得交换机能够将消息路由到正确的队列。绑定通常使用交换机类型和路由键(routing key)来确定消息的路由方式。每个队列可以绑定到一个或多个交换机,而交换机也可以绑定到一个或多个队列。
8.RabbitMQ中的消息持久化是如何实现的?
RabbitMQ中的消息持久化是通过两个方面来实现的:
- 持久化的消息:生产者在发送消息时可以将消息标记为持久化(persistent),RabbitMQ会将这些消息写入磁盘,以确保在服务器重启后消息不会丢失。
- 持久化的队列:队列可以被声明为持久化队列,在声明队列时设置durable参数为true。持久化队列会在服务器重启后仍然存在,保证消息的持久性。
消息的持久化对于确保消息不会因为服务器故障或重启而丢失至关重要。当消息和队列都被持久化时,即使RabbitMQ服务器发生故障,消息也能够在恢复后继续被处理。
9.RabbitMQ如何处理消费者的故障?有哪些机制可以确保消息不丢失?
RabbitMQ处理消费者的故障并确保消息不丢失的机制包括:
- 消费者确认(Consumer Acknowledgements):消费者在处理完消息后发送确认消息(ack)给RabbitMQ,告知消息已成功处理。如果消费者发生故障或断开连接,RabbitMQ会将未收到确认消息的消息重新投递给其他消费者,确保消息不丢失。
- 消费者限流(Consumer Flow Control):消费者可以通过设置QoS(Quality of Service)参数来限制从队列中获取消息的速率。消费者可以控制自己的消息处理速度,防止过多的消息被推送给消费者而导致消息堆积。
- 镜像队列(Mirrored Queues):RabbitMQ支持镜像队列,将队列的副本分布在多个节点上。当一个节点发生故障时,消息仍然可以通过其他节点进行处理,确保消息的高可用性和不丢失。
- 持久化消息和队列:通过将消息和队列标记为持久化,在服务器故障或重启后仍然保留消息和队列,避免消息丢失。
10.RabbitMQ如何处理消息的重试?有哪些常见的重试策略?
- RabbitMQ处理消息的重试通常涉及两个方面:消息的持久化和消息的重传机制。
- 持久化:可以通过将消息设置为持久化来确保消息在RabbitMQ重启后不会丢失。消息持久化需要同时设置消息的delivery_mode属性为2,并且确保队列和交换机都是持久化的。
- 重试机制:RabbitMQ没有内置的自动重试机制,但可以通过一些策略来实现消息的重试。常见的重试策略包括:
- 客户端重试:在消费者处理消息时,如果发生错误,可以捕获异常并重新发送消息。
- 延迟重试:使用延迟队列(Delay Queue)来实现重试功能。当消息处理失败时,将消息发送到延迟队列,并设置延迟时间,在指定的时间后再次尝试处理消息。
- 死信队
11.RabbitMQ中的集群是如何工作的?有哪些常见的集群模式?
RabbitMQ中的集群是通过将多个RabbitMQ节点连接在一起来工作的,以实现高可用性和负载均衡。集群中的每个节点都是一个独立的RabbitMQ服务器,它们之间通过网络进行通信和数据同步。
常见的RabbitMQ集群模式包括:
- Mirrored Queue(镜像队列):将队列的消息复制到多个节点上,每个节点都拥有完整的消息副本。这样可以实现消息的冗余存储,提高可靠性和可用性。
- Federation(联邦):将多个独立的RabbitMQ节点连接起来,通过消息的分发和转发实现跨集群的通信。
- Sharding(分片):将消息按照某种规则进行分片,将不同的消息分发到不同的节点上进行处理,以提高处理能力和吞吐量。
12.RabbitMQ如何保证消息的顺序性?
RabbitMQ并不能直接保证消息的顺序性,因为消息的顺序性在分布式系统中很难完全保证。然而,可以通过一些策略和机制来尽可能地实现消息的顺序性:
- 单一消费者:使用单一的消费者来处理队列中的消息,这样可以确保消息被按顺序处理。但这种方式无法实现消息的并行处理和横向扩展。
- 有序分区:将消息按照某种规则进行分区,每个分区有独立的队列和消费者。在每个分区内部可以保证消息的顺序性,但不同分区之间的消息可能无法保证顺序。
- 手动消息排序:将消息的顺序信息包含在消息的内容中,消费者在接收到消息后进行手动的排序和处理。这需要消费者具有维护消息顺序的逻辑,并对消息进行缓存和排序操作
13.RabbitMQ中的消息确认机制是如何保证可靠性传输的?
RabbitMQ中的消息确认机制采用了生产者确认(Publisher Confirm)和消费者确认(Consumer Acknowledgement)的方式来保证消息的可靠性传输。
- 生产者确认:当生产者发送消息到RabbitMQ后,可以选择等待RabbitMQ发送确认回执。如果RabbitMQ成功接收并持久化了消息,就会发送一个确认回执给生产者。如果消息发送失败或者未被持久化,RabbitMQ会发送一个拒绝回执给生产者。生产者根据收到的回执来确认消息是否成功发送。
- 消费者确认:消费者在处理消息时,可以选择发送确认回执给RabbitMQ。当消费者成功处理了一条消息后,会发送一个确认回执给RabbitMQ,告知已经处理完成。如果消费者无法处理消息或者处理过程中发生异常,可以选择拒绝消息,并将消息重新放回队列,或者直接丢弃消息。
通过消息的生产者确认和消费者确认机制,可以保证消息在发送和处理过程中的可靠性传输。
14.怎么保证消息不丢失?
- 持久化(Durability):当设置为持久化的消息,RabbitMQ会尝试将其存储在磁盘上,即使服务器重启也能恢复。如果消费者已经确认了消息,即便生产者宕机,未消费的消息也不会丢失。
- 确认模式(Confirmations):这是一种客户端驱动的确认模式,在发送消息后,消费者必须对收到的消息进行acknowledge,确认收到了消息。如果没有得到确认,RabbitMQ会回退该消息并再次路由给消费者。
- 交易(Transactions):对于重要的操作,可以启用事务,一组消息要么全部成功发送并确认,要么全部回滚。这提供了原子性的消息处理。
- 死信队列(Dead Letter Exchange/Destination):当消息无法被正常路由到任何一个交换机或队列时,会被送入死信队列,开发者可以选择监控并处理这些消息。
- 手动备份和持久策略:定期备份 RabbitMQ 配置和数据文件,以及设置合适的磁盘空间策略,以防因硬盘满等原因导致数据丢失。
几种消息队列的对比
相关文章:

11.面试题——消息队列RabbitMQ
1.RabbitMQ是什么?特点是什么? RabbitMQ是一种开源的消息队列中间件,用于在应用程序之间进行可靠的消息传递。它实现了AMQP(Advanced Message Queuing Protocol)协议,提供了强大的消息处理能力。RabbitMQ的…...

MySQL运维-日志
错误日志 二进制日志 介绍 日志格式 日志查看 日志删除 查询日志 慢查询日志...

synchronized重量级锁的实现原理是怎样的
重量级锁(Heavyweight Locking)是 Java 中 synchronized 关键字的锁机制的一部分,用于在高竞争情况下确保线程的同步。重量级锁主要通过操作系统的线程同步机制实现,通常涉及阻塞线程、上下文切换等开销较大的操作。以下是重量级锁…...

探索 GLTF 的世界:3D 内容的未来
在 3D 内容创作领域,GLTF 正在掀起波澜,成为跨不同平台提供丰富互动体验的未来标准。GL 传输格式 (GLTF) 由 Khronos Group 开发,是一种用于在工具和服务之间传输 3D 模型和场景的开放标准。它设计紧凑、高效且易于集成…...

【深度学习】【语音】TTS, CM-TTS,TTS扩散模型,论文
CM-TTS: Enhancing Real Time Text-to-Speech Synthesis Efficiencythrough Weighted Samplers and Consistency Models CM-TTS: 提高实时文本到语音合成效率 通过加权采样器和一致性模型 Xiang Li 1, Fan Bu 1, Ambuj Mehrish 2, Yingting Li 1, Jiale Han 1, Bo Cheng 1, S…...

【网络协议】网络劫持 - ARP_DNS欺骗篇
前言 网络劫持是一种网络攻击技术,攻击者通过拦截、篡改或重定向数据流量,控制用户的网络通信路径,干扰正常的网络服务。其方式可能包括DNS劫持、ARP欺骗和HTTP劫持等。通过这些手段,攻击者可以窃取敏感信息如个人身份数据和财务信…...

Linux 系统框架分析(一)
一、linux内核结构框图 对内核结构框图有个总体的把握,有助于理解为什么驱动要这样写,为什么写的应用程序所用的C库接口能够产生这么多的事情。 框图可以看出来,linux系统,包括五个系统 一、Linux内核结构介绍 Linux 内核是操作…...

Leetcode 剑指 Offer II 090.打家劫舍 II
题目难度: 中等 原题链接 今天继续更新 Leetcode 的剑指 Offer(专项突击版)系列, 大家在公众号 算法精选 里回复 剑指offer2 就能看到该系列当前连载的所有文章了, 记得关注哦~ 题目描述 一个专业的小偷,计划偷窃一个环形街道上沿街的房屋&a…...

上海冷链配送新篇章 华鼎冷链科技以卓越服务餐饮品牌
在快速发展的上海餐饮连锁行业中,冷链运输作为保障食品安全与品质的关键环节,正迎来前所未有的发展机遇与挑战。华鼎冷链科技作为该领域的佼佼者,正引领着上海乃至全国冷链运输行业的新风尚。 华鼎冷链科技的成功并非一蹴而就。首先ÿ…...

学习鸿蒙-应用市场申请签名
1.需要的文件概念 .cer / .p7b / .p12 / .csr HarmonyOS应用/服务通过数字证书(.cer文件)和Profile文件(.p7b文件)来保证应用/服务的完整性。在申请数字证书和Profile文件前,首先需要通过DevEco Studio来生成密钥&am…...

LayUi插件
文档:日期和时间组件文档 - Layui layDate安装 npm install layui-laydate...

使用tailwindcss轻松实现移动端rem适配
本示例节选自小卷全栈开发实战系列的《Vue3实战》。演示如何用tailwindcss所支持的rem体系轻松实现一个仿b站移动端头部导航栏rem适配。 友情声明 学习分享不易,如果小伙伴觉得有帮助,点赞支持下。满30赞,将随文附赠录屏讲解,感谢…...

2021-11-08 51单片机2位秒表启动清零
缘由c51单片机,程序,仿真图,求帮助-编程语言-CSDN问答 #include "REG52.h"sbit K1 P1^0; sbit K2 P1^1; sbit K3 P1^2; sbit K4 P1^3; sbit P1_0P2^0; sbit P1_1P2^1; sbit P1_2P2^2; sbit P1_3P2^3; sbit P1_4P2^4; sbit P1_…...

谈基于大语言模型的图数据库路径检索
随着微软已经开源了GraphRAG项目的代码,基于图数据库的RAG 热度迅速升温。关注基于大语言模型与图模型数据库相结合的技术的人多了起来。 本文提出了一种类似人工搜索的“顺藤摸瓜”方法,实现图数据库的智能搜索方法。 本地私有数据存储和查询 本地私有…...

XHTML 简介
XHTML 简介 XHTML,即“可扩展超文本标记语言”(eXtensible HyperText Markup Language),是一种基于XML的标记语言,旨在取代HTML作为网页内容的标准格式。XHTML继承了HTML的基本结构,但更加严格和规范&…...

驱动开发系列10 - Linux Graphics 图形栈介绍
目录 一:Linux 图形栈总体结构 1. 整体图形栈: 2. 现代3D图形栈: 二:Xorg 介绍 Xorg 概述: Xorg的发展历史: Xorg绘制原理: Xorg的缺点: 三:Wayland 介绍 一:Linux 图形栈总体结构 1. 整体图形栈: 应用程序->桌面环境->GUI框架->Display Client->Displ…...

Docker快速入门指南
🛠️ Docker 应用场景 Docker 是一个开源的平台,旨在简化应用程序的开发、部署和管理。它通过容器技术,将应用及其所有依赖打包在一个标准化的环境中,从而确保应用在不同环境中的一致性和可移植性。在 Python 爬虫的场景中&#…...

VS Code中使用MSVC编译C++程序
前置条件 1. VS Code配置C开发环境 2. CMake安装 3. VS安装(MSVC编译器) 4. 环境变量配置(重要!!!) 使用msvc的cl工具编译程序,以及 “fatal error C1034: iostream: 不包括…...

四数之和(LeetCode)
题目 给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复): 0 <…...

学习使用备份软件BorgBackup
Time Machine是官方提供的强大备份系统,它能够备份macOS系统的一切,包括文件、照片、网页纪录、帐号密码以及安装过的软件等。如果系统出了问题,使用”时光回溯“,系统就能回到任意记录点,用过的多说好! B…...

Java 实现合并两个有序链表:递归与迭代
Java 实现合并两个有序链表:递归与迭代 在面试和算法题中,合并两个有序链表是一个经典问题。通过这个问题,不仅可以考察候选人的基础数据结构掌握情况,还能测试他们对递归和迭代等编程技巧的应用能力。 本文将讨论如何使用 Java…...

【每日刷题】Day98
【每日刷题】Day98 🥕个人主页:开敲🍉 🔥所属专栏:每日刷题🍍 🌼文章目录🌼 1. 大数加法_牛客题霸_牛客网 (nowcoder.com) 2. 大数乘法_牛客题霸_牛客网 (nowcoder.com) 3. 扑克牌…...

51单片机-LED实验二
使用51单片机进行LED灯的实验,使用8个LED灯展示二进制数,使用独立按键控制二进制数的加法,每次按下独立按键K2,就让二进制数加一,定义了一个LedNum,表示二进制数,二进制数取反之后可以得到输出到LED端口的8…...

批发行业进销存-webview 读取NFC,会员卡 源码CyberWinApp-SAAS 本地化及未来之窗行业应用跨平台架构
一、混合应用开发 混合应用顾名思义就是网页html和原生APP共同作用的结果 好处在一既有web的跨平台优势(安卓、苹果,电脑、国产电脑、平板电脑,自助机都能用) 好处二可以离线使用,比较稳定 好处三可以与本地硬件交…...

博弈dp,CF 731E - Funny Game
一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 731E - Funny Game 二、解题报告 1、思路分析 游戏规则其实就是交替取前缀和 考虑 f(i) 为 某人先手取前 i 个,最终能得到的最大分差 由于每人都是最佳发挥,所以有如下状态转移&am…...

基础知识:深入理解MongoDB、MySQL与Redis的应用与实践
基础知识:深入理解MongoDB、MySQL与Redis的应用与实践 在现代应用开发中,数据库系统的选择对于系统的性能、扩展性和维护性有着至关重要的影响。MongoDB、MySQL 和 Redis 是三种流行的数据库技术,它们各自有着独特的特点和适用场景。本文将详…...

Reids中List类型、Set类型、SortedSet类型的常用指令
List类型: Redis中的List类型与Java中的LinkedList类似,可以看做是一个双向链表结构。既可以支持正向检索和也可以支持反向检索。 特征也与LinkedList类似: 有序元素可以重复插入和删除快查询速度一般 常用来存储一个有序数据,…...

K8S Ingress 常用配置
目录 介绍ingress 安装 基本使用请查看域名重定向前后端分离配置默认证书配置指定证书配置白名单配置黑名单配置Annotations 配置ConfigMap 配置 匹配请求头速率限制限制客户端的最大连接数限制每秒钟段并发连接数限制每分钟段并发请求突发访问限制限制传输速度速率限制白名单 …...

【K8S】K8S架构及相关组件
文章目录 1 K8S总体架构2 相关组件2.1 控制面板组件2.2 节点组件2.3 附加组件 写在最后 1 K8S总体架构 K8S,全称Kubernetes,是一个开源的容器部署和管理平台,由Google开发,后捐献给云原生计算基金会(CNCF)…...

【MATLAB第108期】基于MATLAB的fast、vbsa、dynia、eet、glue、pawn、rsa敏感性分析模型合集(无目标函数)【更新中】
【MATLAB第108期】基于MATLAB的fast、vbsa、dynia、eet、glue、pawn、rsa敏感性分析模型合集(无目标函数)【更新中】 一、FAST(Fourier Amplitude Sensitivity Test) FAST(Fourier Amplitude Sensitivity Test&#…...