Redis 面试题 | 02.精选Redis高频面试题

🤍 前端开发工程师、技术日更博主、已过CET6
🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1
🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》
🍚 蓝桥云课签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》
文章目录
- 5. Redis的分布式锁实现方式有哪些?
- 6. Redis的过期键处理机制是怎样的?
- 7. Redis的LRU算法是如何工作的?
- 8. Redis的事务是如何实现的?
5. Redis的分布式锁实现方式有哪些?
Redis的分布式锁实现方式有以下几种:
-
客户端锁:客户端锁是指在客户端使用Redis的SET命令设置锁,当客户端尝试获取锁时,如果锁已经被其他客户端持有,则返回失败。客户端锁适用于简单的场景,如单客户端并发操作。
-
服务端锁:服务端锁是指在Redis服务器上使用SET命令设置锁,当客户端尝试获取锁时,如果锁已经被其他客户端持有,则返回失败。服务端锁适用于复杂的场景,如多客户端并发操作,可以保证锁的公平性和一致性。
-
分布式锁:分布式锁是指在Redis集群中使用SET命令设置锁,当客户端尝试获取锁时,如果锁已经被其他客户端持有,则返回失败。分布式锁可以保证锁的公平性和一致性,适用于高并发场景。
-
布隆过滤器:布隆过滤器是指使用Redis的布隆过滤器数据结构实现分布式锁,当客户端尝试获取锁时,如果锁已经被其他客户端持有,则返回失败。布隆过滤器可以保证锁的公平性和一致性,适用于高并发场景。
-
乐观锁:乐观锁是指在客户端使用Redis的WATCH、MULTI、EXEC等命令实现分布式锁,当客户端尝试获取锁时,如果锁已经被其他客户端更新,则返回失败。乐观锁可以保证锁的公平性和一致性,适用于高并发场景。
-
分布式锁服务:分布式锁服务是指使用第三方开源服务,如
Redisson、REDIS-CLUSTER等,实现分布式锁。分布式锁服务可以提供高性能、高可用性和可扩展性的分布式锁服务。
6. Redis的过期键处理机制是怎样的?
Redis的过期键处理机制如下:
-
设置过期时间:在设置键值对时,可以通过EXPIRE命令设置键的过期时间,单位为秒。例如,SET mykey “Hello, World!” EXPIRE 10。
-
自动过期:当键的过期时间到达时,Redis会自动删除该键。
-
定期检查过期键:Redis会定期执行TTL命令,检查键的过期时间,如果过期时间到达,则自动删除该键。
-
手动删除过期键:可以使用PERSIST命令,将键的过期时间设置为永久,从而避免该键被自动删除。例如,PERSIST mykey。
-
过期键的内存占用:Redis会优先删除内存占用较大的过期键,以保证Redis的内存使用效率。
-
过期键的过期处理优先级:Redis会优先处理设置的过期时间,其次处理自动过期和定期检查过期的时间。
-
过期键的处理方式:Redis会根据键的过期时间、内存占用和处理优先级等条件,决定是否删除过期键。
-
过期键的处理策略:Redis提供了多种过期键的处理策略,如定期清理、LRU算法、LFU算法等,可以根据实际需求进行选择。
7. Redis的LRU算法是如何工作的?
Redis的LRU(Least Recently Used,最近最少使用)算法是一种缓存淘汰策略,用于根据键的使用情况决定是否删除缓存。
LRU算法的实现过程如下:
-
初始化:当Redis启动时,将所有键的访问时间设置为0,表示未访问。
-
访问键:当客户端访问键时,将该键的访问时间设置为当前时间,表示该键被访问。
-
淘汰键:当Redis的内存使用达到限制时,会执行LRU算法,选择最近最少使用的键进行淘汰。具体步骤如下:
a. 计算每个键的访问时间,并将访问时间按照从小到大的顺序进行排序。
b. 删除访问时间最早的键,即最近最少使用的键。
-
访问键:当客户端再次访问该键时,将该键的访问时间设置为当前时间,表示该键被访问。
-
更新访问时间:当Redis执行其他操作时,如设置键值对、执行过期处理等,也会更新键的访问时间,从而保证LRU算法的正确性。
-
定期检查:Redis会定期执行LRU命令,检查键的访问时间,以确保LRU算法的正确性。
LRU算法的优点是能够根据键的访问情况自动淘汰缓存,从而保证Redis的内存使用效率。但缺点是可能会导致客户端访问某个键时需要等待较长时间,因为该键的访问时间可能会被更新。
8. Redis的事务是如何实现的?
Redis的事务(Transaction)是指一组原子操作,保证整个操作要么全部成功,要么全部失败。Redis的事务实现是基于Redis的WATCH、MULTI、EXEC三个命令。
以下是Redis事务的实现过程:
-
客户端发送WATCH命令,指定要监视的键。例如,WATCH mykey1 mykey2。
-
客户端执行事务内的操作,例如设置键值对、修改键值等。
-
客户端发送MULTI命令,表示事务开始。例如,MULTI。
-
客户端执行事务内的操作,例如设置键值对、修改键值等。
-
客户端发送EXEC命令,表示事务提交。例如,EXEC。
-
Redis服务器根据客户端发送的命令执行事务,如果事务执行成功,则返回客户端执行的所有操作的结果;如果事务执行失败,则返回错误信息。
Redis事务的优点是能够保证整个操作的原子性,即要么全部成功,要么全部失败。但缺点是需要客户端与服务器之间同步通信,可能会导致性能下降。
以下是Redis事务的示例:
WATCH mykey
SET mykey "Hello, World!"
MULTI
EXEC
在这个示例中,客户端首先使用WATCH命令监视mykey键,然后使用SET命令设置键的值为"Hello, World!"。接着,客户端使用MULTI命令开始事务,然后使用EXEC命令提交事务。如果mykey键已经被其他客户端修改,则事务执行失败,返回错误信息。如果mykey键未被修改,则事务执行成功,返回设置的键值对。
相关文章:
Redis 面试题 | 02.精选Redis高频面试题
🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…...
大数据开发之kafka(完整版)
第 1 章:Kafka概述 1.1 定义 Kafka是一个分布式的基于发布/订阅模式的消息队列,主要应用于大数据实时处理领域。 发布/订阅:消息的发布者不会将消息直接发送给特定的订阅者,而是将发布的消息分为不同的类别,订阅者只…...
单体架构、微服务和无服务器架构
前言 在这篇文章中,我将演示在决定使用单体架构、微服务架构和无服务器架构时的权衡的简化心智模型。目标是突显每种风格的固有优势和缺陷,并提供关于何时选择哪种架构风格的指导。 单体架构 对于小团队或项目来说是理想的入门架构。它简单易上手&…...
Github仓库使用方式
主要参考: 「详细教程」使用git将本地项目上传至Github仓库(MacOS为例)_github上传代码到仓库-CSDN博客 新建文件夹参考: GitHub使用指南——建立仓库、建立文件夹、上传图片详细教程-CSDN博客 一、新建一个 github 仓库&#…...
Harmony Ble蓝牙App(四)描述符
Harmony Ble蓝牙App(四)描述符 前言正文一、优化二、描述① 概念② 描述提供者③ 显示描述符 三、源码 前言 上一篇中了解了特性和属性,同时显示设备蓝牙服务下的特性和属性,本文中就需要来使用这些特性和属性来完成一些功能。 正…...
C# 实现单线程异步互斥锁
文章目录 前言一、异步互斥锁的作用是什么?示例一、创建和销毁 二、如何实现?1、标识(1)标识是否锁住(2)加锁(3)解锁 2、异步通知(1)创建对象(2&a…...
Java设计模式中策略模式可以解决许多if-else的代码结构吗? 是否能满足开闭原则?
Java设计模式中策略模式可以解决许多if-else的代码结构吗? 是否能满足开闭原则? 是的,策略模式可以帮助解决许多if-else的代码结构。通过将不同的算法封装成不同的策略类,然后在需要的时候动态地切换策略,可以避免使…...
[C#]C# winform部署yolov8目标检测的openvino模型
【官方框架地址】 https://github.com/ultralytics/ultralytics 【openvino介绍】 OpenVINO(Open Visual Inference & Neural Network Optimization)是由Intel推出的,用于加速深度学习模型推理的工具套件。它旨在提高计算机视觉和深度学…...
力扣刷MySQL-第五弹(详细讲解)
🎉欢迎您来到我的MySQL基础复习专栏 ☆* o(≧▽≦)o *☆哈喽~我是小小恶斯法克🍹 ✨博客主页:小小恶斯法克的博客 🎈该系列文章专栏:力扣刷题讲解-MySQL 🍹文章作者技术和水平很有限,如果文中出…...
用C语言实现简单的三子棋游戏
目录 1 -> 模块简介 2 -> test.c 3 -> game.c 4 -> game.h 1 -> 模块简介 test.c:测试游戏逻辑 game.c: 函数的实现 game.h:函数的声明 2 -> test.c #define _CRT_SECURE_NO_WARNINGS 1#include "game.h";void menu() {printf("****…...
Yaklang 中的类型和变量
Yaklang 的类型其实非常简单,我们仅需要记住如下类型即可 string 字符串类型,用以快速构建一个字符串int 整数类型:在 64 位机中,int 和 int64 是一样的float 浮点类型,用来定义和表示浮点数byte 本质上等同于 uint8u…...
C语言从入门到实战——编译和链接
编译和链接 前言一、 翻译环境和运行环境二、 翻译环境2.1 预处理(预编译)2.2 编译2.2.1 词法分析2.2.2 语法分析2.2.3 语义分析 2.3 汇编2.4 链接 三、 运行环境 前言 在C语言中,编译和链接是将源代码转换为可执行文件的两个主要步骤。 编…...
【实战教程】ThinkPHP6分页功能轻松实现,让你的网站更高效!
ThinkPHP是一款非常流行的PHP开发框架,其最新版本ThinkPHP6在性能和易用性方面都得到了很大的改善。分页功能是网页开发中非常常见的功能,而ThinkPHP6也提供了非常方便的分页方法。本文将介绍如何实现ThinkPHP6的分页功能。 一、了解分页功能 在Web应用…...
专业130+总分380+哈尔滨工程大学810信号与系统考研经验水声电子信息与通信
今年专业课810信号与系统130,总分380顺利考上哈尔滨工程大学,一年的努力终于换来最后的录取,期中复习有得有失,以下总结一下自己的复习经历,希望对大家有帮助,天道酬勤,加油!专业课&…...
旅游项目day08
1. 旅游日记(游记) 后端:实体类,列表,查看,审核 前端:目的地明细中-游记->带范围条件查询,游记首页,【扩展】游记添加/编辑,【扩展】添加游记时间没登录时…...
蓝桥杯真题(Python)每日练Day2
题目 题目分析 对于本题首先确定其数据结构为优先队列,即邮费最小的衣服优先寄,算法符合贪心算法。可以直接使用queue库的PriorityQueue方法实现优先队列。关于PriorityQueue的使用方法主要有: import queue q queue.Queue()# 队列 pq qu…...
IntelliJ IDEA 拉取gitlab项目
一、准备好Gitlab服务器及项目 http://192.168.31.104/root/com.saas.swaggerdemogit 二、打开 IntelliJ IDEA安装插件 打开GitLab上的项目,输入项目地址 http://192.168.31.104/root/com.saas.swaggerdemogit 弹出输入登录用户名密码,完成。 操作Comm…...
RHCSA上课笔记(前半部分)
第一部分 网络服务 第一章 例行性工作 1.单一执行的例行性工作 单一执行的例行性工作(就像某一个时间点 的闹钟):仅处理执行一次 1.1 at命令:定时任务信息 [rhellocalhost ~]$ rpm -qa |grep -w at at-spi2-core-2.40.3-1.el9.x…...
C++代码入门05 字符串容器
图源:文心一言 上机题目练习整理,本篇作为字符串容器的代码,提供了常规解法及其详细解释,供小伙伴们参考~🥝🥝 第1版:在力扣新手村刷题的记录~🧩🧩 方法:常…...
vue3 项目中 arguments 对象获取失败问题
问题 在 vue3 项目中 获取到的 arguments 对象与传入实参不符,打印出函数中的 arguments 对象显示如下: 原因 作者仔细回看代码才发现,自己一直用的是 vue3 的组合式写法,函数都是箭头函数,而箭头函数不存在 argumen…...
网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...
国防科技大学计算机基础课程笔记02信息编码
1.机内码和国标码 国标码就是我们非常熟悉的这个GB2312,但是因为都是16进制,因此这个了16进制的数据既可以翻译成为这个机器码,也可以翻译成为这个国标码,所以这个时候很容易会出现这个歧义的情况; 因此,我们的这个国…...
高频面试之3Zookeeper
高频面试之3Zookeeper 文章目录 高频面试之3Zookeeper3.1 常用命令3.2 选举机制3.3 Zookeeper符合法则中哪两个?3.4 Zookeeper脑裂3.5 Zookeeper用来干嘛了 3.1 常用命令 ls、get、create、delete、deleteall3.2 选举机制 半数机制(过半机制࿰…...
前端开发面试题总结-JavaScript篇(一)
文章目录 JavaScript高频问答一、作用域与闭包1.什么是闭包(Closure)?闭包有什么应用场景和潜在问题?2.解释 JavaScript 的作用域链(Scope Chain) 二、原型与继承3.原型链是什么?如何实现继承&a…...
重启Eureka集群中的节点,对已经注册的服务有什么影响
先看答案,如果正确地操作,重启Eureka集群中的节点,对已经注册的服务影响非常小,甚至可以做到无感知。 但如果操作不当,可能会引发短暂的服务发现问题。 下面我们从Eureka的核心工作原理来详细分析这个问题。 Eureka的…...
智能AI电话机器人系统的识别能力现状与发展水平
一、引言 随着人工智能技术的飞速发展,AI电话机器人系统已经从简单的自动应答工具演变为具备复杂交互能力的智能助手。这类系统结合了语音识别、自然语言处理、情感计算和机器学习等多项前沿技术,在客户服务、营销推广、信息查询等领域发挥着越来越重要…...
快刀集(1): 一刀斩断视频片头广告
一刀流:用一个简单脚本,秒杀视频片头广告,还你清爽观影体验。 1. 引子 作为一个爱生活、爱学习、爱收藏高清资源的老码农,平时写代码之余看看电影、补补片,是再正常不过的事。 电影嘛,要沉浸,…...
LangFlow技术架构分析
🔧 LangFlow 的可视化技术栈 前端节点编辑器 底层框架:基于 (一个现代化的 React 节点绘图库) 功能: 拖拽式构建 LangGraph 状态机 实时连线定义节点依赖关系 可视化调试循环和分支逻辑 与 LangGraph 的深…...
LCTF液晶可调谐滤波器在多光谱相机捕捉无人机目标检测中的作用
中达瑞和自2005年成立以来,一直在光谱成像领域深度钻研和发展,始终致力于研发高性能、高可靠性的光谱成像相机,为科研院校提供更优的产品和服务。在《低空背景下无人机目标的光谱特征研究及目标检测应用》这篇论文中提到中达瑞和 LCTF 作为多…...
协议转换利器,profinet转ethercat网关的两大派系,各有千秋
随着工业以太网的发展,其高效、便捷、协议开放、易于冗余等诸多优点,被越来越多的工业现场所采用。西门子SIMATIC S7-1200/1500系列PLC集成有Profinet接口,具有实时性、开放性,使用TCP/IP和IT标准,符合基于工业以太网的…...
