【后端开发面试题】每日 3 题(二十)
✍个人博客:Pandaconda-CSDN博客
📣专栏地址:https://blog.csdn.net/newin2020/category_12903849.html
📚专栏简介:在这个专栏中,我将会分享后端开发面试中常见的面试题给大家,每天的题目都是独立且随机的,之前的面试题不会影响接下来的学习~
❤️如果有收获的话,欢迎点赞👍收藏📁,您的支持就是我创作的最大动力💪
题目 1: 什么是分布式一致性?常见的分布式一致性算法有哪些?
答案:
分布式一致性是指在分布式系统中,多个节点之间如何保持数据的一致性。由于网络延迟、节点故障等问题,实现一致性是一个复杂的挑战。
常见的分布式一致性算法:
-
Paxos
- 特点:一种经典的分布式一致性算法,通过多轮投票机制达成共识。
- 优点:理论基础扎实,适合强一致性场景。
- 缺点:实现复杂,难以理解和调试。
-
Raft
- 特点:比 Paxos 更易于理解,通过领导者选举、日志复制和安全性保证一致性。
- 优点:逻辑清晰,适合教学和工程实践。
- 缺点:性能略逊于 Paxos,在极端场景下可能不够灵活。
-
ZAB (Zookeeper Atomic Broadcast)
- 特点:Zookeeper 使用的协议,支持顺序性和原子性广播。
- 优点:专为 Zookeeper 设计,性能稳定。
- 缺点:与 Zookeeper 深度绑定,适用范围有限。
-
Gossip 协议
- 特点:基于流言传播的方式同步数据,适用于大规模分布式系统。
- 优点:去中心化,扩展性强。
- 缺点:最终一致性,无法保证强一致性。
-
Quorum(多数派协议)
- 特点:通过写入和读取的多数派机制保证一致性。
- 优点:简单高效,适合分布式存储系统。
- 缺点:对网络分区敏感。
总结:
- 对于强一致性要求高的场景,选择 Paxos 或 Raft。
- 对于大规模弱一致性场景,选择 Gossip 协议或 Quorum。
题目 2: 如何设计一个高可用的消息队列系统?请描述核心组件和实现思路。
答案:
消息队列系统用于解耦生产者和消费者,提升系统的可靠性和扩展性。以下是设计高可用消息队列系统的核心组件和实现思路:
核心组件:
-
消息存储
- 使用持久化存储(如 Kafka 的分区日志、RabbitMQ 的队列)确保消息不会丢失。
- 支持多副本机制(如 Leader-Follower)提高可靠性。
-
消息分发
- 实现负载均衡策略(如轮询、随机分配),将消息均匀分发到消费者。
- 支持批量消费和异步处理,提升吞吐量。
-
高可用性
- 使用主从复制或多活架构避免单点故障。
- 支持故障检测和自动切换。
-
监控与报警
- 监控消息堆积、延迟和消费速率等指标。
- 在异常情况下触发报警通知。
-
扩展性
- 支持动态扩容和缩容,适应流量变化。
实现思路:
-
选择合适的消息队列工具
- 根据需求选择 Kafka(高吞吐量)、RabbitMQ(灵活性强)或 RocketMQ(事务支持)。
-
设计分区与副本
- 将消息分散到多个分区,每个分区有多副本以提高可靠性。
-
实现消息确认机制
- 消费者在成功处理消息后发送 ACK,确保消息不会重复消费或丢失。
-
优化性能
- 批量发送和消费消息,减少网络开销。
- 使用压缩算法(如 Snappy、Gzip)降低存储成本。
-
处理消息积压
- 设置合理的 TTL(生存时间),自动清理过期消息。
- 增加消费者实例,提升消费能力。
示例:
以下是一个简单的高可用消息队列架构:
- 使用 Kafka Cluster 实现分区和多副本存储。
- 使用 Zookeeper 管理集群元数据和故障切换。
题目 3: 什么是服务限流与熔断?它们的区别是什么?如何实现服务限流与熔断?
答案:
服务限流和服务熔断是微服务架构中常用的容错机制,用于保护系统的稳定性和可用性。
服务限流:
- 定义:限制请求的速率或并发数,防止系统过载。
- 作用:保护下游服务,避免因流量过大导致崩溃。
- 实现方式:
- 使用令牌桶算法或漏桶算法控制请求速率。
- 示例:每秒最多允许 100 次请求。
服务熔断:
- 定义:当某个服务出现故障或响应时间过长时,快速失败并返回错误信息。
- 作用:防止雪崩效应,保护下游服务。
- 实现方式:
- 使用熔断器模式(如 Hystrix、Resilience4j)。
- 定义熔断阈值(如连续失败次数)和恢复时间窗口。
区别:
| 特性 | 服务限流 | 服务熔断 |
|---|---|---|
| 触发条件 | 流量过大或超出设定阈值 | 服务不可用或响应超时 |
| 目标 | 控制请求速率,保护系统稳定性 | 快速失败,防止级联故障 |
| 实现方式 | 限制请求速率或并发数 | 拦截请求并返回错误信息 |
示例:
- 限流:API 网关限制每秒最多 50 次请求,超出部分返回 429 错误。
- 熔断:支付服务不可用时,直接返回错误信息,避免用户等待。
相关文章:
【后端开发面试题】每日 3 题(二十)
✍个人博客:Pandaconda-CSDN博客 📣专栏地址:https://blog.csdn.net/newin2020/category_12903849.html 📚专栏简介:在这个专栏中,我将会分享后端开发面试中常见的面试题给大家,每天的题目都是独…...
搭建个人博客教程(Hexo)
如何快速搭建一套本地的博客系统呢?这里有一套gitNode.jsHexo的部署方案来进行解决。 安装git Git 是一款免费开源的分布式版本控制系统,由 Linus Torvalds 于 2005 年为 Linux 内核开发设计。它通过本地仓库和远程仓库实现代码管理,支持分支…...
Docker 可视化工具 Portainer
Docker 可视化工具 Portainer安装 官方安装地址:https://docs.portainer.io/start/install-ce/server/docker/wsl 一,首先,创建 Portainer Server 用来存储数据库的卷: docker volume create portainer_data二,然后…...
数据库基础知识点(系列二)
1.关系数据模型由哪三个要素组成。 答:关系数据模型由关系数据结构、关系操作集合和关系完整性约束三部分组成。 2.简述关系的性质。(关系就是一张二维表格,但不是任何二维表都叫关系) 答:(1…...
Docker-Compose部署 EasySearch 异常问题排查
近期将原本运行在 macOS 上的 EasySearch、Console 和 Coco-server 等服务迁移至群晖 NAS 平台。在迁移过程中遇到了EasySearch容器无法正常启动或运行中意外终止的问题。本文记录了这些问题的具体表现及解决方案,旨在为后续类似部署提供参考。 基础部署配置 以下…...
如何进行灌区闸门自动化改造-闸门远程控制系统建设
改造背景 操作效率低:人工启闭耗时耗力,单次操作需2-3人配合,耗时长。 水资源浪费:依赖经验估算放水量,易导致漫灌或供水不足。 管理滞后:无法实时监控水位、流量,故障响应延迟。 …...
深入解析 Vue3 响应式系统:原理、性能优化与应用场景
文章目录 1. Vue3 响应式系统的基本原理:Proxy 与 Reflect1.1 Proxy 和 Reflect 概述1.1.1 Proxy1.1.2 Reflect1.1.3 Proxy 和 Reflect 的协作 1.2 Vue3 响应式系统:如何通过 Proxy 实现数据代理1.3 Vue3 中 Proxy 的核心概念:响应式数据的创…...
C++11QT复习(二)
文章目录 Day4-4 New 与 delete 表达式(2025.03.20)1. new 表达式的三个步骤2. delete 表达式的两个步骤3. new[] 与 delete[] Day5 类的定义和关键字再探(2025.03.24)1. C 关键字 const、static、extern2. 类的定义:C…...
【数据挖掘】数据预处理——以鸢尾花数据集为例
数据预处理——以鸢尾花数据集为例 一、实验手册(一)实验目的(二)实验原理(三)实验环境(四)实验步骤(五)实验报告要求 二、案例代码(以鸢尾花数据…...
【算法笔记】图论基础(二):最短路、判环、二分图
目录 最短路松弛操作Dijkstra朴素Dijkstra时间复杂度算法过程例题 堆优化Dijkstra时间按复杂度算法过程例题 bellman-ford时间复杂度为什么dijkstra不能处理负权边?dijkstra的三个步骤:反例失效的原因 算法过程例题 spfa时间复杂度算法过程例题spfa求最短…...
HTTP/HTTPS 中 GET 请求和 POST 请求的区别与联系
一、基础概念 HTTP (HyperText Transfer Protocol, 超文本传输协议) 是一种用于浏览器与服务器之间进行数据交互的协议。HTTPS (加密的 HTTP) 则通过 SSL/TLS 协议实现通信加密与数据安全性。 二、GET 和 POST 概述 GET 请求: 用于从服务器获取资源。 POST 请求: 用于将数据…...
Spring、Spring Boot与Spring Cloud深度解析:核心关系与实战应用指南
1. 技术定位 Spring Framework:企业级Java开发的基础框架Spring Boot:快速构建独立运行的Spring应用Spring Cloud:分布式系统开发的微服务全家桶 二、Spring Framework核心解析 1. 关键特性 // 典型Spring MVC控制器示例 Controller Reque…...
EMS小车技术特点与优势:高效灵活的自动化输送解决方案
北成新控伺服技术丨EMS小车调试视频 EMS小车是一种基于单轨运行的电动输送系统,通过电力驱动实现物料的高效搬运和输送,具有高效灵活、节能环保、多功能集成、行业适配性强等特性,广泛应用于汽车制造、工程机械、家电生产、仓储物流等行业自动…...
uniapp运行到支付宝开发者工具
使用uniapp编写专有钉钉和浙政钉出现的样式问题 在支付宝开发者工具中启用2.0构建的时候,在开发工具中页面样式正常 但是在真机调试和线上的时候不正常 页面没问题,所有组件样式丢失 解决 在manifest.json mp-alipay中加入 "styleIsolation&qu…...
C++ 性能优化隐藏陷阱:从系统调用到并发开销的深度反思
作为一名C++技术专家,我深知性能优化不仅是代码层面的艺术,更是理解硬件与语言交互的科学。在现代计算中,C++的抽象为开发者提供了便利,却也隐藏了硬件的复杂性。如何揭开这些“谎言”,让代码与硬件协同工作?本文将以小案例为载体,通过优化前后的对比,深入剖析每个章节…...
Unity 使用 Protobuf(Pb2)二进制数据全流程工具详解
前言 在Unity游戏开发中,高效、快速、安全地读取配置数据是一项重要需求。本文介绍一种完整的解决方案——使用Protobuf二进制格式(Pb2)存储和读取游戏数据,并详细分享实现全流程的Unity工具。 一、技术流程概览 实现Unity读取…...
基于QT(C++)实现绘图程序
绘图程序 1 核心算法 1.1 图元生成 1.1.1 直线 画直线的算法采用了课上讲到的 Bresenhan 算法,采用整数增量运算,精确而有效的光栅设备生成算法。 基本思想是:当直线斜率的绝对值小于 1 时,从左端点开始作为起点&#…...
深入剖析ReLU激活函数:特性、优势与梯度消失问题的解决之道,以及Leaky ReLU 和 Parametric ReLU
深入剖析ReLU激活函数:特性、优势与梯度消失问题的解决之道 在深度学习领域,激活函数的选择直接影响神经网络的训练效果和性能。整流线性单元(Rectified Linear Unit,简称ReLU)因其简单性、高效性以及对梯度消失问题的…...
vscode设置console.log的快捷输出方式
vscode设置console.log的快捷输出方式 编辑器中输入clg回车,可以直接输出console.log,并且同步输出变量的字符串和值 1、打开vscode点击左上角的文件 2、找到首选项 3、点击用户代码配置 4、在顶部输入框种输入javas,选择JavaScript选项 5、…...
服务注册/服务发现-Eureka
目录 1.引言:如果一个父项目中有多个子项目,但是这些子项目如何如何相互调用彼此的业务呢? 2.什么是注册中心 3.CAP理论 4.EureKa 5.服务注册 6.服务发现 7.负载均衡 1.引言:如果一个父项目中有多个子项目,但是…...
【机器学习】什么是随机森林?
什么是随机森林? 随机森林(Random Forest)是一种集成学习方法,它通过组合多个决策树来提高预测的准确性和鲁棒性。可以把随机森林看作是“森林”,而森林中的每棵树就是一个决策树。每棵树独立地做出预测,最…...
【Rust】一文掌握 Rust 的详细用法(Rust 备忘清单)
文章目录 入门配置 vscode 调试Hello_World.rs原始类型格式化打印风格变量注释函数声明宏元变量结构体元组结构体单元结构体 语句与表达式语句表达式 区间表达式 Rust 类型类型别名整数浮点数布尔值字符字符串字面量数组切片元组 Rust 字符串字符串字面量字符串对象.capacity()…...
为什么后端接口返回数字类型1.00前端会取到1?
这得从axios中得默认值说起: Axios 的 transformResponse axios 在接收到服务器的响应后,会通过一系列的转换函数(transformResponse)来处理响应数据,使其适合在应用程序中使用。默认情况下,axios 的 tran…...
单片机串口打印调试信息②
在STM32开发中,使用串口(UART)打印调试信息是调试嵌入式程序的核心手段。以下是基于STM32 HAL库的详细实现步骤和调试策略: 一、硬件准备 硬件连接: STM32开发板:以STM32F4系列为例,选择任意UAR…...
Windows下安装常用软件--MySQL篇
Windows下安装常用软件--MySQL篇 文章说明安装指导安装MySQL脚本 资料下载 文章说明 记录一下Windows下安装zip版的MySQL,采用简洁的方式安装,便于学习使用;作为对该篇文章的修正与完善(MySQL 关于 zip安装) 安装指导 …...
Qt 高效读写JSON文件,玩转QJsonDocument与QJsonObject
一、前言 JSON作为轻量级的数据交换格式,已成为开发者必备技能。Qt框架为JSON处理提供了完整的解决方案,通过QJsonDocument、QJsonObject和QJsonArray三大核心类,轻松实现数据的序列化与反序列化。 JSON vs INI 特性JSONINI数据结构支持嵌…...
计算机网络——数据链路层的功能
目录 物理链路 逻辑链路 封装成帧(组帧) 帧定界 透明传输 SDU 差错控制 可靠传输 流量控制 介质访问控制 主机需要实现第一层到第五层的功能,而路由器这种节点只需要实现第一层到第三层的这些功能 假设左边用户需要给右边用户发送…...
第60天:Web攻防-XSS跨站文件类型功能逻辑SVGPDFSWFPMessageLocalStorage
#知识点 1、Web攻防-XSS跨站-文件类型-html&pdf&swf&svg 2、Web攻防-XSS跨站-功能逻辑-postMessage&localStorage 术语:上传xss->其实就是将有恶意js代码的各类文件(swf,pdf,svg,html.xml等)上传->访问该文件->让浏…...
C/C++都有哪些开源的Web框架?
CppCMS CppCMS是一个采用C语言开发的高性能Web框架,通过模版元编程方式实现了在编译期检查RESTful路由系统,支持传统的MVC模式和多种语言混合开发模式。 CppCMS最厉害的功能是WebSocket,10万连接在内存中长期保存占用的大小不超过600MB&…...
RISC-V AIA学习2---IMSIC
我在学习文档这章时,对技术术语不太理解,所以用比较恰当的比喻来让自己更好的理解。 比较通俗的理解: 将 RISC-V 系统比作一个工厂: hart → 工厂的一条独立生产线IMSIC → 每条生产线配备的「订单接收员」MSI 中断 → 客户通过…...
