当前位置: 首页 > news >正文

长沙建网站制作公司/企业网站建设论文

长沙建网站制作公司,企业网站建设论文,公司网站要怎么做,点样做网站在本篇文章中,主要是介绍RabbitMQ一些常见的面试题。对于前几篇文章的代码,都已经在码云中给出,链接是mq-test: 学习RabbitMQ的一些简单案例 (gitee.com),如果存在问题的话欢迎各位提出,望共同进步。 MQ的作用以及应用…

在本篇文章中,主要是介绍RabbitMQ一些常见的面试题。对于前几篇文章的代码,都已经在码云中给出,链接是mq-test: 学习RabbitMQ的一些简单案例 (gitee.com),如果存在问题的话欢迎各位提出,望共同进步。

MQ的作用以及应用场景

简单来说,MQ的全称是Message Queue(消息队列),因此MQ的作用就是接收消息和发送消息。具体来说,MQ就是一种应用程序间的通信方法,它允许组件以异步的方式进行交互,在不同的应用场景下发挥着不同的作用。

常见的应用场景有:异步解耦、削谷削峰、消息分发、延迟通知、异步通信等。

具体介绍见【RabbitMQ】概述一文。

不同MQ的区别

业界也有许多MQ的产品,例如Kafka、RabbitMQ、RocketMQ等。

Kafka一开始是作为日志收集和传输,追求高吞吐量,性能卓越。单机吞吐量一般可达十万级,在日志领域较为成熟。但是功能比较简单,只支持简单的MQ功能。适合大数据处理、实时分析、日志聚合等应用场景。

RabbitMQ是采用Erlang语言开发,功能较为完善,几乎支持所有的主流语言,开源提供的界面非常友好,性能较好,单机吞吐量一般可达万级,社区活跃度较高,文档更新频繁。比较适合中小型公司,数据量没那么大、并且并发没那么高的场景。

RocketMQ是阿里巴巴开源的一款消息队列,后来捐赠给Apache公司,采用Java语言开发。在可用性、可靠性以及稳定性方面都非常出色,吞吐量可达十万级,在阿里巴巴内部广泛使用。但是支持的语言并不多,产品较新文档较少,并且社区活跃度一般。适合于大规模分布式系统,而且可靠性要求较高的场景,比如互联网金融。

具体介绍见【RabbitMQ】概述一文。

RabbitMQ的核心概念

 核心概念这一问题可以大概构建上述图形来简单进行介绍,我习惯先介绍生产者、消费者,然后再介绍连接、信道,最后介绍Broker以及其中的内容,VirtualHost、Exchange、Queue。

  • Producer(生产者):是RabbitMQ Server的客户端,向RabbitMQ Server发送消息。
  • Consumer(消费者):是RabbitMQ Server的客户端,从RabbitMQ Server接收消息。
  • Connection(连接):是RabbitMQ Server和客户端之间的一个TCP连接,该连接是客户端和服务端之间发送消息的基础,他负责传输客户端和服务端之间的所有数据和控制信息。
  • Channel(信道、通道):信道是连接之上的一个抽象层。在一个连接中有多个信道,每个信道都是独立的虚拟连接,消息的发送和接收就是基于信道的。信道的主要作用是将消息的读写操作复用到同一个TCP连接上,这样就可以减少建立连接和关闭连接的开销,提高性能。
  • Broker:本质上就是RabbitMQ Server这个服务端实例,主要用来接收和发送消息。
  • VirtualHost(虚拟主机):虚拟主机是一个虚拟概念,他为消息队列提供了一种逻辑上的隔离机制。对于一个RabbitMQ Server而言,可以存在多个虚拟主机。当多个不同的用户需要同一个Rabbit Server提供的服务时,可以划分出多个虚拟主机。每个用户在自己的虚拟主机上创建交换机、队列即可。
  • Exchange(交换机):消息到达Broker的第一站,她负责接收消息并且根据路由规则把消息路由到对应的消息队列中。交换机起到了消息路由的作用,她根据交换机的规则和类型来确认如何转发接收到的消息。
  • Queue(队列):用于存储消息。

具体介绍见【RabbitMQ】概述一文。

RabbitMQ的工作流程

  1. 发送消息:生产者生成了一条消息。
  2. 创建连接:生产者和RabbitMQ Server之间创建连接,并且开启一个信道。
  3. 声明交换机、队列以及绑定关系:生产者声明一个队列,用来存放消息;生产者声明一个交换机,用来路由消息;生产者指定一个绑定规则,使得消息从交换机成功路由到队列中。
  4. 发送消息:生产者将消息发送给RabbitMQ Server。
  5. 消息存储:RabbitMQ Server接收到消息之后,根据路由规则存入相应的队列中。如果未找到相应的队列,根据生产者的配置,选择丢弃或者回退给生产者。
  6. 消费消息:消费者监听队列,当消息到达时,从队列中获取消息。处理后,向Rabbit Server发送消息确认。
  7. 删除消息:RabbitMQ Server接收到消费者的确认(ACK)之后,从队列中把消息删除。

具体介绍见【RabbitMQ】概述一文。

RabbitMQ如何保证消息的可靠性

如何保证消息的可靠性,就要看消息在传输过程中哪里出现了问题。大致分为三个方面:第一个是从生产者到交换机、再到队列的过程,第二个是RabbitMQ Server内部,第三个是从RabbitMQ Server内部到消费者的过程。RabbitMQ对这三种情况分别推出了三种解决方案:发送方确认、持久化以及消息确认。

发送方确认有两种模式:第一个是confirm模式,保证的是从生产者到交换机过程中的消息可靠性。第二个是return模式,保证的是从交换机到队列的消息可靠性。

持久化有三种方式,分别是交换机持久化、队列持久化以及消息持久化。在三个持久化中,主要注意的是队列持久化和消息持久化,如果消息持久化了但是队列没持久化是没有作用的,比较队列都没有,消息也没地方放,自然持久化也就没有用。

消息确认有两种模式:手动确认和自动确认,在SpringAMPQ中,则是有三种策略可以选择:NONE、AUTO、MANUAL。在MANUAL中,又有三种机制可供选择,分别是接收、拒绝以及批量拒绝。

具体介绍见【RabbitMQ】可靠性传输​​​​​一文。

RabbitMQ如何保证消息的顺序性

RabbitMQ中顺序性指的是生产者生产消息的顺序为msg1、msg2、msg3,那么消费者消费消息的顺序也应该依次为msg1、msg2、msg3。顺序性保障分为局部顺序性保障和全局顺序性保障。存在的解决方案有:单队列单消费者、分区消费、消息确认、业务逻辑控制(例如消费端内部实现消息排序逻辑等)。

具体介绍见【RabbitMQ】幂等性、顺序性一文。

RabbitMQ如何保证消息的幂等性

RabbitMQ中幂等性指的是一条消息,多次消费,对系统产生的影响是相同的。

在消息传递过程中,消息传输保证被分为最少一次、恰好一次、最多一次。RabbitMQ并不支持恰好一次;在业务场景比较重要的情况下,建议使用最少一次,但是在一些特殊场景下(例如消息从生产者发送出去之后出现网络故障,导致服务端没有及时返回确认机制;或者消息从服务端到消费者,消费之后并没有返回确认通知)会导致消息重复发送,从而出现一些比较严重的问题;对于最多一次来说,则会因为网络宕机等故障导致消息丢失。

一般在比较重要的业务下,我们都是以最少一次这种方式,但是如果出现消息重复传输的话,就会导致消息多次消费,因此我们为了保证幂等性,就需要一些解决方案。常见的解决方案有:

  • 使用唯一标识符来标识每一条消息
  • 使用业务逻辑判断来确认消息是否消费

具体介绍见【RabbitMQ】幂等性、顺序性一文。

RabbitMQ有哪些特性

  • 消息可靠性传输
    • 发送方确认
    • 持久化
    • 消息确认
  • 死信队列
  • 延迟队列
  • 重试机制
  • TTL

具体介绍见【RabbitMQ】系列。

介绍下RabbitMQ的死信队列

死信表示一系列无法被消费的消息。存在死信,就存在死信队列。当一个消息在队列中变成死信之后,就会通过死信交换机进入死信队列,这就是死信队列的由来。

例如队列中的消息超过最大长度、消息的TTL超时、手动确认机制下拒绝并且不予重新入队等等,都会被路由到死信队列中。

死信队列的应用场景有:消息重试(将错误的消息放入死信队列中进行重试)、日志分析(将死信队列中的消息进行收集,用户日志分析)、消息丢弃(将死信队列中的消息丢弃,避免占用资源)。

具体介绍见【RabbitMQ】死信队列、延迟队列一文。

介绍下RabbitMQ的延迟队列

延迟队列表示消息从生产者到达RabbitMQ Server之后,并不是立即到达消费者进行消费,而是经过一段时间之后再推送到消费者。

延迟队列的实现方式有两种:

  1. TTL + 死信队列(注意这里的TTL必须要设置队列的,而不是消息的)。
  2. 使用延迟队列插件。

延迟队列的应用场景有:

  • 十五分钟未支付订单取消
  • 预定会议开始前十五分钟进行通知
  • 手机遥控两个小时之后家电开始工作
  • 用户注册成功之后,三天后发送通知,提供用户活跃度
  • 用户发起退款,24小时之后商家没有行动,自动退款

具体介绍见【RabbitMQ】死信队列、延迟队列一文。

介绍下RabbitMQ的工作模式

RabbitMQ有七种工作模式,分别是:

  • 简单模式(Simple)
  • 工作队列模式(Work Queue)
  • 发布订阅模式(Publish / Subscribe)
  • 路由模式(Routing)
  • 通配符模式(Topics)
  • RPC模式(RPC)
  • 发布确认模式(Publisher Confirms)

具体介绍见【RabbitMQ】工作模式一文。

消息积压

消息积压指的是生产者生产消息的速度已经远远超过了消费者消费消息的速度,从而导致了消息在队列中发生了积压。

导致消息积压的原因无非就是软件和硬件的原因。对于软件来说,就是生产者生产速度太快、而消费者消费速度太慢;对于硬件来说,就是网络延迟、RabbitMQ服务器配置太低等原因。

想要解决消息积压,就是针对产生的问题进行分别解决。对于软件来说,就是提高消费者消费速率、降低生产者生产速率;对于硬件来说,就是增加服务器配置、优化参数等方案。

具体介绍见【RabbitMQ】消息积压、推拉模式一文。

推拉模式

推拉模式是RabbitMQ中向消费者发送消息的两种模式。推模式表示的是消息到达服务器之后,根据消费者监听的队列将消息推送给消费者进行消费。拉模式表示的是消息到达服务器之后,消费者主动去服务器拉取消息进行消费。

对于一般的业务来说,采取的都是推模式进行工作,其适合数据实时性要求较高的场景。拉模式则是适合消费消息时需要大量资源的的任务,拉模式允许消费者准备好之后再去进行消费,可以减少资源的浪费。

具体介绍见【RabbitMQ】消息积压、推拉模式一文。

到这里,RabbitMQ的介绍就基本结束了,其中缺的一个内容就是分布式部署,有机会的话后续进行介绍。

总的来说,在RabbitMQ这个系列中,先进行了一个概述,然后对工作模式简单介绍,后续是对高级特性(可靠性保证、TTL、重试机制、延迟队列、死信队列、事务、消息分发、幂等性、顺序性、消息积压)以及推拉模式进行了介绍,最后对一些场景面试题进行了概述。

下一个系列文章是微服务组件,欢迎大家给出修改意见,共同进步。

相关文章:

【RabbitMQ】面试题

在本篇文章中,主要是介绍RabbitMQ一些常见的面试题。对于前几篇文章的代码,都已经在码云中给出,链接是mq-test: 学习RabbitMQ的一些简单案例 (gitee.com),如果存在问题的话欢迎各位提出,望共同进步。 MQ的作用以及应用…...

Python软体中使用TensorFlow实现一个简单的神经网络:从零开始

使用TensorFlow实现一个简单的神经网络:从零开始 在现代数据科学和机器学习领域,神经网络是一个强大的工具。TensorFlow是一个广泛使用的开源库,专门用于机器学习和深度学习。本文将详细介绍如何使用TensorFlow实现一个简单的神经网络。我们将从基础概念开始,逐步深入到代…...

StopWath,apache commons lang3 包下的一个任务执行时间监视器的使用

StopWath是 apache commons lang3 包下的一个任务执行时间监视器&#xff0c;与我们平时常用的秒表的行为比较类似&#xff0c;我们先看一下其中的一些重要方法&#xff1a; <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 --> <dependen…...

ELMO理论

目录 1 优点 2 缺点 3.知识点个人笔记 2018年3月份&#xff0c;ELMo出世&#xff0c;该paper是NAACL18 Best Paper。在之前2013年的word2vec及2014年的GloVe的工作中&#xff0c;每个词对应一个vector&#xff0c;对于多义词无能为力。ELMo的工作对于此&#xff0c;提出了一…...

EMU 街机模拟器编译方法

安装ubuntu 16.04 下载gcc 8.2 安装 然后安装automake 1.16 ,1.15 安装jdk8 sdk 里面配套的ndk 21e 编译库 cd ~/emu-ex-plus-alpha/imagine/bundle/all/ export IMAGINE_PATH/home/lxm/emu-ex-plus-alpha/imagine export ANDROID_SDK_ROOT/home/lxm/Sdk export ANDROID_NDK_…...

c++开发之编译curl(windows版本)

在 Windows 上编译支持 OpenSSL 的 cURL 库并不简单&#xff0c;因为涉及到多个库的依赖关系以及工具链的配置。以下是编译支持 OpenSSL 的 cURL 库的详尽步骤&#xff1a; 环境要求 编译工具链&#xff1a; MinGW 或 Visual StudioCMakePerl (用于编译 OpenSSL)NASM (用于编译…...

IT运维挑战与对策:构建高效一体化运维管理体系

在当今数字化时代&#xff0c;IT运维作为企业运营的核心支撑&#xff0c;其重要性不言而喻。然而&#xff0c;随着业务规模的扩大和技术的不断革新&#xff0c;IT运维团队面临着前所未有的挑战。本文旨在深度剖析当前IT运维中存在的主要问题&#xff0c;并探索一体化解决方案&a…...

前海石公园的停车点探寻

前海石公园是真的很美&#xff0c;很多看海人&#xff0c;很多钓鱼佬&#xff0c;很多抓螃蟹的人&#xff0c;很多挖沙子的人&#xff0c;很多拍照的人&#xff0c;尤其是没有大太阳的时间段或每天傍晚或每个放假的时候人气超高&#xff0c;故前海石公园停车真的很紧张。由于前…...

嵌入式学习--线性表Day01

嵌入式学习--线性表Day01 顺序表 1.1数组的插入、删除操作 1.2修改为last版本 1.3顺序表相关操作 顺序表、单向链表、单向循环链表、双向链表、双向循环链表、顺序栈、链式栈、循环队列&#xff08;顺序队列&#xff09;、链式队列 1&#xff09;逻辑结构&#xff1a;线性结构 …...

Rust 全局变量的最佳实践 lazy_static/OnceLock/Mutex/RwLock

在实际项目开发中&#xff0c;难免需要用到全局变量&#xff0c;比如全局配置信息&#xff0c;全局内存池等&#xff0c;此类数据结构可能在多处需要被使用&#xff0c;保存为全局变量可以很方便的进行修改与读取。 在Rust中&#xff0c;如果只是读取静态变量是比较简单的&…...

【L波段差分干涉SAR卫星(陆地探测一号01组)】

L波段差分干涉SAR卫星&#xff08;陆地探测一号01组&#xff09; L波段差分干涉SAR卫星&#xff08;陆地探测一号01组&#xff09;是我国自主研发的重要卫星系统&#xff0c;以下是对该卫星的详细介绍&#xff1a; 一、基本信息 卫星组成&#xff1a;陆地探测一号01组由A星…...

第五部分:6---信号的递达

目录 信号的递达流程&#xff1a; 信号在什么时候递达&#xff1f; 用户态和内核态&#xff1a; 内核态、用户态在页表的映射关系&#xff1a; 操作系统如何得知当前执行状态是用户态还是内核态&#xff1f; 操作系统如何处理被捕捉的信号&#xff1f; 信号的递达流程&am…...

深入解析 ARM64 SOC RK3568的 /proc/interrupts 输出

在 Linux 系统中&#xff0c;/proc/interrupts 文件提供了系统中断的详细信息&#xff0c;是性能分析和故障排除的重要工具。本文将重点解析 RK3568环境下该文件的输出格式及其背后的结构。 什么是 /proc/interrupts&#xff1f; /proc/interrupts 文件记录了所有中断的信息&…...

Android常用C++特性之std::unique

声明&#xff1a;本文内容生成自ChatGPT&#xff0c;目的是为方便大家了解学习作为引用到作者的其他文章中。 std::unique 是 C 标准库中的一个算法函数&#xff0c;用于移除相邻的重复元素&#xff0c;使每个相邻的元素在容器中保持唯一。它不会真正移除元素&#xff0c;而是通…...

Redis篇(Java操作Redis)

目录 讲解一&#xff1a;简介 讲解二&#xff1a;Jedis Github 一、创建项目、 二、添加依赖 三、配置文件 四、Java连接Redis 五、通过Redis连接池获取连接对象并操作服务器 六、封装JedisUtil对外提供连接对象获取方法 七、Java操作Redis五种数据类型 1. 连接与释放…...

Cypress自动化Github workflow

目录 Workflow .github/workflows/build.yaml jobs build-deploy: .github/wrokflows/execute-tests.yaml 输入参数 jobs restart_failed_dp: seed_data: execute-tests: Docker File docker/Dockerfile.base docker/service-dockerfile.base Deploy deploy/tes…...

Hbase高阶知识:HBase的协处理器(Coprocessor)原理、使用实例、高级技巧和案例分析

目录 第一章 Hbase概述与基础知识 1.1 HBase的架构与数据模型 1.2 什么是协处理器 1.3 协处理器的优势 第二章 协处理器的工作原理 2.1 协处理器的运行机制 2.2 协处理器的注册与监听 2.3 协处理器与RegionServer的交互 第三章 协处理器的类型 3.1 端点协处理器 3.2…...

海尔嵌入式硬件校招面试题及参考答案

使用 QT 的经验及对控件和信号与槽机制的了解 我使用 QT 有一段时间了,在项目开发中积累了较为丰富的经验。 QT 中的控件丰富多样,涵盖了各种常见的界面元素需求。例如按钮、文本框、列表框、进度条等。这些控件具有良好的可定制性,可以通过属性设置、样式表等方式来调整外观…...

Leetcode基础算法篇|202409(4)贪心算法

贪心算法&#xff08;Greedy Algorithm&#xff09;&#xff1a;一种在每次决策时&#xff0c;总是采取在当前状态下的最好选择&#xff0c;从而希望导致结果是最好或最优的算法。 学习链接&#xff1a;leetcode-notes/docs/ch04/04.04/04.04.02-Exercises.md at main datawha…...

echarts 导出pdf空白原因

问题阐述 页面样式&#xff1a; 导出pdf: 导出pdf&#xff0c;统计图部分为空白。 问题原因 由于代码中进行了dom字符串的复制&#xff0c;而echarts用canvas绘制&#xff0c;canvas内部内容不会进行复制&#xff0c;只会复制canvas节点&#xff0c;因此导出pdf空白。 解决…...

数据结构及基本算法

目录 第一章 概论 第一节 引言 第二节 基本概念和常用术语 第三节 算法的描述与分析 第二章 线性表 第一节 线性表定义和基本运算个 一、线性表的逻辑定义 二、线性表的基本运算 第二节 线性表的顺序存储和基本运算的实现 一、线性表的顺序存储 二、顺序表上基本运算…...

vue3学习记录-computed

vue3学习记录-computed 1.为什么要用computed2.使用方法2.1 基本实例2.2 可写计算属性 1.为什么要用computed 写个购物车的案例 <script setup> import { ref, reactive,computed } from "vue" const tableData reactive([{ name: 商品1, price: 10, num: 1…...

SQLite3模块使用详解

目录 一、引言 1.1 SQLite3 简介 1.2 Python sqlite3 模块 二、连接数据库 2.1 导入 sqlite3 模块 2.2 连接数据库 2.3 创建游标对象 三、执行 SQL 语句 3.1 创建表 3.2 插入数据 3.3 查询数据 3.4 更新数据 3.5 删除数据 四、处理查询结果 4.1 fetchall() 4.2…...

防火墙详解(三)华为防火墙基础安全策略配置(命令行配置)

实验要求 根据实验要求配置防火墙&#xff1a; 合理部署防火墙安全策略以及安全区域实现内网用户可以访问外网用户&#xff0c;反之不能访问内网用户和外网用户均可以访问公司服务器 实验配置 步骤一&#xff1a;配置各个终端、防火墙端口IP地址 终端以服务器为例&#xff…...

假期学习--iOS中的static关键字

iOS中的static关键字 OC的static关键字 OC也提供了Static关键字&#xff0c;但是这个static关键字不能用于修饰成员变量&#xff0c;也就是说Static是不被允许修饰实例变量&#xff0c;同时Static关键字也不被允许修饰方法。Static关键字可以修饰全局变量&#xff0c;局部变量…...

Maya没有Arnold材质球

MAYA 没有Arnold材质球_哔哩哔哩_bilibili...

面试知识点总结篇三

一、arm中断流程和函数 ARM 中断流程 中断触发保存上下文中断向量表执行ISR - 清除中断标志恢复上下文返回中断 二、STM32任务间通信有哪些方式 消息队列、 信号量、共享内存、任务通知 三、uboot内存没驱动之前是怎么操作的 硬件初始化内存检测设置内存映射控制台初始化…...

数据加密标准(DES)详解:原理、步骤及Python实现

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐&#xff1a;「storm…...

每日OJ_牛客_OR59字符串中找出连续最长的数字串_双指针_C++_Java

目录 牛客_OR59字符串中找出连续最长的数字串 题目解析 C代码1 C代码2 C代码3 Java代码 牛客_OR59字符串中找出连续最长的数字串 字符串中找出连续最长的数字串_牛客题霸_牛客网 题目解析 双指针&#xff1a; 遍历整个字符串&#xff0c;遇到数字的时候&#xff0c;用双…...

虚幻引擎UE5如何云渲染,教程来了

​步骤一&#xff1a;获取云渲染权限 访问渲染101官网&#xff0c;使用云渲码6666进行注册。 下载并安装渲染客户端。 步骤二&#xff1a;设置渲染环境 确保云渲染环境与您的本地环境一致&#xff0c;避免出错。 步骤三&#xff1a;任务提交 完成环境配置后&#xff0c;解析…...