RabbitMq面试题总结

news2024/11/25 3:53:55

一. 为什么选择RabbitMq?

1.支持持久化消息,持久化消息主要是指我们机器在不可抗力因素等情况下挂掉了,消 息不会丢失的机制。
2.支持高并发,erlang语言面向并发面向消息的函数编程语言,可以很快创建轻量级线程。
3.社区活跃度

二.为什么使用RabbitMq(有个什么业务场景用到mq可以增大效率)

1.解耦
新增两个服务不需要改动之前代码,只需订阅相对的队列即可

2.异步
   假如没有消息队列,同步处理,需要16ms才能返回结果
   假如短信服务宕机,依旧可以完成下订单,等待短信服务上线再进行消费

3.削峰(时间换空间)

 

三.如何保证消息的不丢失?

1.确保消息到mq(发送方确认模式打开)
工作机制:消息从生产者投递到exchange(信道),会返回一个confirmCallback。无论是否投递成功,都会返回。当ack=true,表示成功,当ack=fase,表示失败

2.确保消息路由到正确的队列(开启路由失败通知)回退模式
当消息由Exchange路由到queue失败后,如果设置了 spring.rabbitmq.template.mandatory=true,则消息回回退给消息生产者producer,并执行回调函数
3.确保消息再队列中正确的存储(交换器、消息、队列都需要持久化)
4.确保消息从队列中正确的投递给消费者(取消自动确认,开启手动确认)

自动确认是指,当消息一旦被Consumer接收到,则自动确认收到,并将相应 message 从 RabbitMQ 的消息缓存中移除。但是在实际业务处理中,很可能消息接收到,业务处理出现异常,那么该消息就会丢失。
手动确认方式,则需要在业务处理成功后,调用channel.basicAck(),手动签收,如果出现异常,则调用channel.basicNack()方法,让其自动重新发送消息。


四.重复消息的产生,如何防止重复消费?

1.发送消息到消息中间件,消息存储成功但发送端没有收到发送成功的消息返回而重试
2.将消息投递给消费者消费,消费成功没有收到成功返回而重复投递

解决
主要是要求消费者来处理这种重复的操作,要求消息接收者的消息处理的幂等性的。
比如一条sql语句执行多次,不会影响实际数据情况,成为幂等操作。

1.MVCC多版本并发控制,是乐观锁的一种实现,再生产者发送消息时带上数据的版本号,相同的版本号只有一次成功的机会,一旦失败必须重新获取新的版本号重新消费。
2.去重表(将唯一的数据作为表的id进行插入,一旦失败直接返回达到不重复消费)


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/765195.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++核心编程之函数高级使用

目录 一、函数的默认参数 二、函数占位参数 三、函数重载 四、函数重载-注意事项 一、函数的默认参数 在C中,函数的形参列表中的形参是可以有默认值的 语法:返回值类型 函数名 (参数默认值){} 示例1: #includ…

【原创】实现ChatGPT中Transformer模型之输入处理

作者:黑夜路人 时间:2023年7月 Inputs Process(输入处理层)实现 我们看整个绿色框的整个位置,就是Inputs Process(输入处理层)。 在输入处理层,其实非常容易理解,主要就…

Proxy代理前后,Httpheader 的变化

Vite.config 配置Proxy服务器, 解决Rest API 访问SpringBoot接口时,跨域的Session一致性。 import { defineConfig, loadEnv } from viteexport default defineConfig({server: {proxy: {/rest: {target: loadEnv(, process.cwd()).VITE_API_URL,changeOrigin: tru…

分类预测 | MATLAB实现基于Attention-GRU的数据多特征分类预测(门控循环单元融合注意力机制分类预测,含混淆矩阵图、分类图)

分类预测 | MATLAB实现基于Attention-GRU的数据多特征分类预测(门控循环单元融合注意力机制分类预测,含混淆矩阵图、分类图) 目录 分类预测 | MATLAB实现基于Attention-GRU的数据多特征分类预测(门控循环单元融合注意力机制分类预测,含混淆矩阵图、分类图…

python_day9_面向对象

# 设计一个类(设计一张登记表) class Student:name Nonegender Nonenative Noneage None# 创建一个对象(打印一张登记表) stu_1 Student() # 对象属性赋值(填表) stu_1.name jay stu_1.gender "…

Django实现接口自动化平台(十二)自定义函数模块DebugTalks 序列化器及视图【持续更新中】

上一章: Django实现接口自动化平台(十一)项目模块Projects序列化器及视图【持续更新中】_做测试的喵酱的博客-CSDN博客 本章是项目的一个分解,查看本章内容时,要结合整体项目代码来看: python django vue…

AI:Illustrator 2023 for mac

illustrator是一款矢量图形编辑软件,用于创建和编辑排版、图标、标志、插图和其他类型的矢量图形。 以下是illustrator的几个特点: 矢量图形:illustrator创建的图形是矢量图形,可以无限放大而不失真,这与像素图形编辑…

Linux Lite 6.6发行版的候选版(RC)可供公众测试

导读Linux Lite的创建者Jerry Bezencon近日宣布,即将推出的Linux Lite 6.6发行版的候选版(RC)开发版本可供公众测试。 Linux Lite 6.6仍然基于Ubuntu 22.04.2 LTS(Jammy Jellyfish)长期支持的操作系统系列,…

数据结构0X-线性结构-链表栈队列

文章目录 参考:总结大纲要求线性结构-链表 参考: 总结 本系列为C数据结构系列,会介绍 线性结构,简单树,特殊树,简单图等。本文为线性结构部分。 大纲要求 线性结构 【 3 】链表:单链表、双向…

truffle 进行智能合约测试

0字 本方法使用了可视化软件Ganache 前两步与不使用可视化工具的步骤是一样的(有道云笔记),到第三步的时候需要注意: 在truffle插件下找到networks目录,提前打开Ganache软件 在Ganache中选择连接或者新建&#xff0…

动手学深度学习v2 p2 线性神经网络 线性回归

3. 线性神经网络 回归(regression)是能为一个或多个自变量与因变量之间关系建模的一类方法。 在自然科学和社会科学领域,回归经常用来表示输入和输出之间的关系。 在机器学习领域中的大多数任务通常都与预测(prediction&#xf…

科技云报道:数字化转型完成后,制造业如何走向“数智”时代?

科技云报道原创。 随着我国数字化转型行动的深入推进和智能制造工程的大力实施,制造业正朝着“数智”时代迈进,生成式AI被视为推动制造业智能化发展的关键驱动力。 据预测,到2027年,将有30%的制造业采用生成式AI来提升产品研发效…

前端Vue仿微信我的菜单栏组件按钮组件

随着技术的发展,开发的复杂度也越来越高,传统开发方式将一个系统做成了整块应用,经常出现的情况就是一个小小的改动或者一个小功能的增加可能会引起整体逻辑的修改,造成牵一发而动全身。 通过组件化开发,可以有效实现…

谷歌 Bard 深夜更新:支持中文、语音输入/播报、代码导出、对话分享

“ 降维打击:你永远想象不到自己的对手会是谁,干掉我们的不一定是同行。谷歌会被ChatGPT 打败吗?” 01 — 两天前,Bard!谷歌对 ChatGPT 的最强反击,悄咪咪的支持中文了!。今天谷歌官方公布了更新…

ModaHub魔搭社区:AI原生云向量数据库Zilliz Cloud设置运维窗口和设置时区

目录 概述 查看运维窗口 编辑运维窗口 相关文档 查看当前时区 编辑时区 相关文档 Zilliz Cloud 允许用户为集群设置运维窗口,以减少运维对工作负载的影响,增加可预测性。 概述 目前,运维窗口设置为全局设置,应用于 Zilliz Cloud 上的所有集群。 为避免在业务高峰期…

基于 rsync 像 macOS 的 Time Machine 一样备份您的 Linux 服务器

一、前言 Time Machine 这东西用过 macOS 的都知道,可以说是数据备份神器。 前几天我误删了几个文件,还好我有设置 Time Machine 自动备份,于是我打开 Time Machine,点几下鼠标,文件就回来了! 我想要是 …

【Docker】Docker镜像和Docker容器

文章目录 Docker镜像镜像基本概念为什么需要镜像?Union FS(联合文件挂载)docker镜像原理 Docker镜像命令docker rmidocker savedocker loaddocker historydocker image prune docker镜像实战离线迁移镜像镜像存储的压缩与共享 Docker容器容器…

npm link 实现全局运行package.json中的指令

packages.json "name":"testcli","bin": {"itRun": "index.js"},执行命令 npm link如果要解绑定 npm unlink testcli 现在你可以输入 itRun试一下

vue3使用下载附件功能

效果&#xff1a; 点击即可以下载打开。 代码&#xff1a; <div v-show"item.attachment.length > 0"><h3>下载附件</h3><divv-for"(doc, docIndex) in item.attachment":key"docIndex"><astyle"color: #41…

WebSocket集群解决方案,不用MQ

首先不了解WebSocket的可以先看看这篇文章&#xff0c;以及传统的WebSocket方案是怎么做的&#xff0c;https://www.cnblogs.com/jeremylai7/p/16875115.html 这是用MQ解决的版本&#xff0c;那么这种方案存在什么问题呢。 第一&#xff1a;增加MQ&#xff0c;可能造成消息挤压…