RabbitMQ必会的8个知识点

1.什么是RabbitMQ?
RabbitMQ是一个开源的消息中间件,用于在不同应用程序之间传递和存储消息。它实现了AMQP(Advanced Message Queuing Protocol)协议,提供了一个可靠的消息传递机制,支持诸如消息持久性、消息发布与订阅、消息路由和消息的顺序性等特性。

2.RabbitMQ是如何保证消息的可靠性传递?
RabbitMQ通过持久性、确认机制和重试机制来保证消息的可靠性传递。
持久性指的是将消息存储在磁盘上,即使RabbitMQ服务器崩溃,也不会丢失消息。
确认机制允许发送方在消息成功发送到队列后收到确认。
重试机制允许消费者处理消息时发生错误时重试处理。

3.RabbitMQ的主要组件是什么?
RabbitMQ的主要组件包括生产者(Producer,发送消息的应用程序)、消息队列(Queue,用于存储消息)、交换器(Exchange,决定将消息发送到哪个队列)、绑定(Binding,连接交换器和队列的规则)和消费者(Consumer,接收和处理消息的应用程序)。

4.RabbitMQ中的Exchange有哪些类型?
RabbitMQ中有四种常用的交换器类型:
Direct Exchange:根据消息的路由键将消息发送到与之完全匹配的队列。
Topic Exchange:根据消息的路由键模式与队列进行匹配。支持通配符匹配。
Fanout Exchange:将消息广播到所有与之绑定的队列,忽略路由键。
Headers Exchange:根据消息的标头来匹配与之绑定的队列。

5.RabbitMQ的消息确认机制是什么?
RabbitMQ提供了消息的确认机制来确保消息被成功接收和处理。生产者消息确认分为两种模式:Confirm模式和事务模式。在Confirm模式下,生产者发送消息并等待RabbitMQ返回确认消息。在事务模式下,生产者发送消息之前先开启事务,然后在消息发送成功后提交事务,或者消息发送失败后回滚事务。

6.使用RabbitMQ有什么好处?
1、服务间高度解耦
2、异步通信性能高
3、流量削峰

7.如何保证RabbitMQ消息的顺序性?
拆分多个queue(消息队列),每个queue(消息队列) 一个consumer(消费者),就是多一些queue(消息队列)而已,确实是麻烦点;
或者就一个queue (消息队列)但是对应一个consumer(消费者),然后这个consumer(消费者)内部用内存队列做排队,然后分发给底层不同的worker来处理。

8.如何保证消息不被重复消费?
在写入消息队列的数据做唯一标示,消费消息时,根据唯一标识判断是否消费过;

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

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

相关文章

startqueue(模拟实现及底层原理)

目录 容器适配器 STL标准库中stack和queue的底层结构 ​deque deque的原理 deque的缺陷 为什么选择deque作为stack和queue的底层默认容器 stack stack的介绍 stack的函数 stack的模拟实现 queue queue的介绍 queue的函数 queue的模拟实现 priority_queue prior…

Android中线程池

一、线程池的优点 说到线程池的优点就要先说一下不用线程池的坏处 在早些年开发都是直接new Thread()直接创建线程,倘若有N个异步就要创建N个线程,这会导致线程的频繁创建和销毁线程不可控,每个线程都各自执行,内存资源竞争激烈&…

js小写金额转大写 自动转换

// 小写转为大写convertCurrency(money) {var cnNums [零, 壹, 贰, 叁, 肆, 伍, 陆, 柒, 捌, 玖]var cnIntRadice [, 拾, 佰, 仟]var cnIntUnits [, 万, 亿, 兆]var cnDecUnits [角, 分, 毫, 厘]// var cnInteger 整var cnIntLast 元var maxNum 999999999999999.9999var…

Leetcode-每日一题【19.删除链表的倒数第N个结点】

题目 给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。 示例 1: 输入:head [1,2,3,4,5], n 2输出:[1,2,3,5] 示例 2: 输入:head [1], n 1输出:[] 示例 3&#x…

数据结构day5(2023.7.19)

一、Xmind整理: 双向链表的插入与删除: 二、课上练习: 练习1:单链表任意元素删除 /** function: 按元素删除* param [ in] * param [out] * return 返回堆区首地址*/ Linklist delete_by_data(datatype key,Linklist L) …

Unity Obfuscator

官方仓库 学习日期:2023-07-13(防止后续仓库特性或功能更新无对比时间) 目标:本文介绍使用此github库,混淆unity项目的代码,在ILSpy中无法正确反编译。 一、说明 官方说明 配置界面 Features: ControlFlow…

XPath 文本匹配:正则表达式的应用与技巧

XPath 文本匹配:正则表达式的应用与技巧 引言1. 正则表达式的基本语法2. 正则表达式的技巧和应用2.1 匹配单词边界2.2 提取匹配的内容3. 示例演示3.1 示例1:基本文本匹配3.2 示例2:匹配单词边界3.3 示例3:提取匹配的内容结论引言

1480. 一维数组的动态和

https://leetcode.cn/problems/running-sum-of-1d-array/ 给你一个数组 nums 。数组「动态和」的计算公式为:runningSum[i] sum(nums[0]…nums[i]) 。 请返回 nums 的动态和。 示例 1:输入:nums [1,2,3,4] 输出:[1,3,6,10] 解…

springboot整合feign实现RPC调用,并通过Hystrix实现服务降级

目录 一、服务提供者 二、服务消费者 三、测试效果 四、开启Hystrix实现服务降级 feign/openfeign和dubbo是常用的微服务RPC框架,由于feigin内部已经集成ribbon,自带了负载均衡的功能,当有多个同名的服务注册到注册中心时,会根…

SpringBoot中集成jasypt-spring-boot实现配置文件数据加密脱敏

场景 经常会遇到这样一种情况:项目的配置文件中总有一些敏感信息,比如数据源的url、用户名、 密码....这些信息一旦被暴露那么整个数据库都将会被泄漏,那么如何将这些配置隐藏呢。 除了使用手动将加密之后的配置写入到配置文件中&#xff…

紧跟国家“新能源+”模式!涂鸦智慧能源方案助力夏季用电节能提效

“今天的你是几分熟?” 今年夏天,高温来得比往年更早,五六月份就提前开启了滚滚热浪模式,京津冀和山东等地最高气温也一度突破了历史极值。在提前到来的高温“烤”验下,全社会供电能力面临着极大挑战。 中国电力网预…

Spring

getBean()方法使用 其中,当参数的数据类型是字符串时,表示根据Bean的id从容器中获得Bean实例,返回是Object,需要强转。 当参数的数据类型是Class类型时,表示根据类型从容器中匹配Bean实例,当容器中相同类型…

手机定屏死机问题操作指南

和你一起终身学习,这里是程序员Android 经典好文推荐,通过阅读本文,您将收获以下知识点: 一、定屏死机问题抓取 Log 要求二、 复现定屏死机问题后做什么三、检查adb是否可连的方法四、连接adb 抓取以下Log五、如果adb不可连,执行下…

reggie优化06-项目部署

1、部署架构 2、部署环境 3、部署前端 4、部署后端 修改图片位置,并push至仓库

C语言的UDP多线程点对点发送消息

windows下使用Dev C调试 Server段&#xff1a; /** * 编译命令&#xff1a;gcc udps.c -lws2_32 -lmycon -lwinmm -o us.exe */ #include <stdio.h> #include <winsock2.h> #include <mycon.h>struct sockaddr_in serveraddr; struct sockaddr_in clien…

全域Serverless化,华为云引领下一代云计算新范式

近日&#xff0c;华为开发者大会2023&#xff08;Cloud&#xff09;在东莞成功举办&#xff0c;期间“全域Serverless化&#xff0c;引领下一代云计算新范式”专题论坛人气满满。华为云首席产品官方国伟携手业界专家、客户、伙伴&#xff0c;面向广大开发者&#xff0c;分享了在…

【Docker】Docker基本管理命令

目录 一、Docker概述1.1容器化受欢迎的原因1.2Docker核心概念 二、安装 Docker2.1环境准备 三、Doker镜像操作镜像操作选项 四 、Docker 容器操作容器操作选项 一、Docker概述 Docker是一个开源的应用容器引擎&#xff0c;基于go语言开发并遵循了apache2.0协议开源。 Docker是…

HTTP1.1、HTTPS、HTTP2.0 、HTTP3.0

HTTP1.1 优点&#xff1a; 整体方面&#xff1a;简单、灵活和易于扩展、应用广泛和跨平台 性能方面&#xff1a;长连接、管道网络传输解决请求队头阻塞&#xff08;没有使用&#xff09; 缺点&#xff1a; 安全方面&#xff1a;无状态、明文窃听、伪装、篡改 性能方面&am…

HTML <meter> 标签

实例 使用 meter 元素来度量给定范围(gauge)内的数据: <meter value="3" min="0" max="10">十分之三</meter><meter value="0.6">60%</meter> 浏览器支持 元素ChromeIEFirefoxSafariOpera<meter>8…

JavaWeb课程设计项目实战(03)——开发准备工作

版权声明 本文原创作者&#xff1a;谷哥的小弟作者博客地址&#xff1a;http://blog.csdn.net/lfdfhl 在正式进入项目开发之前请先完成以下准备工作。 数据库语句 请创建数据库和表并完成数据初始化工作。 初始化数据库 请在MySQL数据库中创建名为studentinformationmanag…