Redis 高频面试题 2023 最新版

news2024/11/24 10:24:03

Redis 高频面试题 2023 最新版

文章目录

  • Redis 高频面试题 2023 最新版
  • 一、Redis缓存相关
    • 1. 什么是缓存穿透?如何解决
    • 2. 什么是缓存击穿?如何解决


一、Redis缓存相关

1. 什么是缓存穿透?如何解决

是什么
缓存穿透就是根据某条件查询一个数据,首先进入到redis中进行查询,redis中没有该数据时进入到数据库中查询,但是在数据库中也没有查到该数据,这个时候数据库直接将没有查到数据这一结果返回,而没有将它缓存到redis中,导致每次按照该条件查询都会进入到数据库中查询,这,就是缓存穿透;

穿透过Redis,去数据库中查数据

在这里插入图片描述
解决方案一:
缓存空数据,按照某一条件查询的数据为空,将这个结果缓存到redis中,这样下次来查询进入到redis就能够查到该数据;
缺点:可能会出现数据不一致问题,当数据库中的值更新时,redis中的数据可能没有进行更新;

解决方案二:

  1. 根据某条件查询信息时,先去布隆过滤器中查询,如果布隆过滤器中存在该数据,则往下走进入redis中去查询数据,如果布隆过滤器中没有值则直接返回;
  2. redis中如果能够查询得到结果,则返回结果,查询不到进入数据库中进行查询;
  3. 数据库查询到结果并返回,而且会将结果缓存在Redis中一份;

在这里插入图片描述


解释说明:

布隆过滤器

  • 缓存热点数据时,需要向布隆过滤器添加率数据;
  • 布隆过滤器的主要作用:拦截不存在的数据;

布隆过滤器的实现

bitmap(位图): 相当于是以一个(bit)为单位的数组,数组中每个单元只能存储二进制数0或1;
布隆过滤器能够检索一个元素是否存在这个集合中

存储数据到bitmap中:
在这里插入图片描述

误判问题
到bitmap中查询某值是否存在,经过三次hash函数计算出结果,发现在bitmap中有存有了值,布隆过滤器便认为已经存储过该值,当你实际上是没存储过的;

在这里插入图片描述

误判率: 数组越小误判率越大,数组越大误判率就越小,但是同时带来了更多的内存消耗; 无法避免,可以控制,一般控制在5%左右;

布隆过滤器的两种实现方案:

  • Redission
  • Guava

2. 什么是缓存击穿?如何解决

是什么
缓存击穿指的是给某个热点key设置了过期时间,当key过期的时候,恰好这个时间点对这个key有大量的并发请求,这些并发请求瞬间把DB给压垮

击穿的是谁?击穿的是数据库

在这里插入图片描述

解决方案一:添加互斥锁(分布式锁)

  1. 线程1去Redis中查找数据,没有找到,此时线程二也在进行Redis查询数据,也没有找到
  2. 然后在此处添加互斥锁,这里假设线程1成功获取了互斥锁,然后他会去数据库中查数据并且将查询到的结果写入Redis中,完成这些操作才会释放同步锁;
  3. 而线程2获取互斥锁失败,会设置它休眠一段时间再去重新读取Redis中的数据,如果还没有在Redis中找到数据,它就会重复执行 查数据、获取锁等操作,直到找到Redis中的数据为止;

此方案的优缺点:优点是保证了数据的强一致性,缺点是性能较差

在这里插入图片描述

方案二:逻辑过期(不设置过期时间)

  1. 线程1去缓存中进行查询,发现逻辑时间已经过期,它就会去获取互斥锁,并去开启新线程;然后就会将这个过期的数据进行返回;
  2. 新开启的线程负责查询数据库重建缓存数据,并在写入缓存时重置逻辑过期时间,完成这些操作后才会释放锁;
  3. 此时线程三如果查询缓存发现数据逻辑时间已过期,会尝试去获取互斥锁,但线程1以拿到互斥锁,因此线程三获取互斥锁失败;但也会返回这个查询到的逻辑时间已过期的内容;
  4. 线程一、二 完成了换成数据重建时,线程四刚好进来,就能够查询到正常的数据,并正常返回

优缺点: 优点是高可用,性能较优,但是无法保证数据的强一致性(过期数据会被返回);

在这里插入图片描述
保证了高可用,性能比较优,单不能保证数据的绝对一致性;

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

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

相关文章

C++STL:顺序容器之forward_list

文章目录 1. 概述2. 成员函数和使用forward_list容器相关的函数 3. forward_list 容器的创建 1. 概述 forward_list 是 C 11 新添加的一类容器,其底层实现和 list 容器一样,采用的也是链表结构,只不过 forward_list 使用的是单链表&#xff…

解决ubuntu cuda版本nvcc -V和nvidia-smi不一致问题

在使用nvcc -V和nvidia-smi查看cuda版本时不一致: nvcc -V版本是10.1 nvidia-smi的版本是12.2 上面如果能显示版本,所以是已经有驱动,首先要删除之前的驱动: 1、执行以下命令,删除旧版本的驱动 sudo apt-get purge …

数据库用户管理

一 目录 一 新建用户 二 用户名的改变 三 删除用户 四 修改用户密码root用户 五 忘记mysql的密码时候怎么办 六 数据库的权限赋予 ​编辑 七 查询用户名的权限 八 权限的撤销 九总结 新建用户 CREATE USER 用户名来源地址 [IDENTIFIED BY [PASSWORD] 密码]; 只是一个用…

node中表单验证捕获第三方库

1.安装 npm install escook/express-joi npm install joi17.4.0 2.使用 2.1创建一个schema文件夹 说明:用于表单规则集,设置表单的规划的 // 导入定义验证的包 const joi require("joi");// 定义用户名和密码的验证规则 const username j…

数据结构(王卓版)——初识数据结构

一、数据结构讲什么: 程序数据结构算法 数据结构的基础以及数据结构的应用方向。 数据、数据元素、数据项、数据对象 数据结构 逻辑结构的种类 存储结构种类 主要学习顺序和链式存储结构。 有时间可以了解,不用重点学。 数据类型: 抽象数据类…

win11利用start11实现全屏菜单,磁贴配置

Win11磁贴配置 最近电脑还是升级到 win11 了。我之前采用的美化方案是桌面上的图标全部移到 win10 开始菜单里的全屏菜单上,用磁贴贴一排。每次要访问文件的时候都去开始菜单里找,而不是放在桌面上,这样桌面也可以空出来欣赏壁纸。参考配置链…

数据库压力测试方法概述

一、前言 在前面的压力测试过程中,主要关注的是对接口以及服务器硬件性能进行压力测试,评估请求接口和硬件性能对服务的影响。但是对于多数Web应用来说,整个系统的瓶颈在于数据库。 原因很简单:Web应用中的其他因素,…

MSP430F249 Proteus仿真智能刷卡计时计费水表系统 -0070

MSP430F249 Proteus仿真智能刷卡计时计费水表系统 -0070 Proteus仿真小实验: MSP430F249 Proteus仿真智能刷卡计时计费水表系统 -0070 功能: Protues版本:8. 9 程序编写:IAR 7.10 硬件组成:MSP430F249 单片机 …

auc的计算方法

方法一 用指示函数表示上式中正样本预测值大于负样本预测值的正负样本对,则得到 p表示预测得分。 在给出的例子中,包含有2个正样本(A, B)和3个负样本(C, D, E),因此一共有6个(2*3)正负样本对,即公式中分母为6。 接下来计算公式…

Rogue DHCP Server攻击(仿冒DHCP Server攻击)

目录 事件原理 DHCP 仿冒攻击 防护方法 事件原理 攻击原理:攻击者仿冒DHCP Server向客户端分配错误的IP地址以及错误的网关等信息,导致用户无法正常的访问网络。漏洞分析:DHCP客户端收到DHCP Server的DHCP消息之后,无法区分这些DHCP消息是来自仿冒的DHCP Server还是…

【NLP】BERT和原理揭示

一、说明 BERT(来自transformer的双向编码器表示)是Google AI Language研究人员最近发表的一篇论文。它通过在各种NLP任务中展示最先进的结果,在机器学习社区引起了轰动,包括问答(SQuAD v1.1),自…

PostgreSQL如何设置主键自增?

本文主题:采用Navicat 连接pgSQL库,如何创建表,如何设置主键自增? 1. 如何通过Navicat 连接pgSQL创建表 详细创建过程可以参考天翼云文章: 参考链接:https://www.ctyun.cn/document/10000047/10030641 2…

一篇完整学习JUC并发编程(包含实例源码)

文章目录 JUC并发编程1、什么是JUC?2、线程和进程并发、并行线程有几个状态? 6个wait/sleep区别? 3、Lock锁传统sychronized锁卖票实例使用Lock锁卖票实例sychnorized 和 lock锁区别 4、生产者和消费者问题synorchized版生产者和消费者问题虚假唤醒问题…

【UT学习记录】

系列文章目录 提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加 Part1:Mock Part2:PowerMock Part3:Junit 提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档 文…

Linux进程信号(二)

信号保存与捕捉 1.相关概念2.信号在内核中的示意图3.信号集4.信号集操作函数5.内核态与用户态6.信号捕捉7.sigaction8.可重入函数8.volatile9.SIGCHLD信号 🌟🌟hello,各位读者大大们你们好呀🌟🌟 🚀&#…

hbuilderX自定义主题仿vscode暗黑主题

目录 hbuilderX自定义主题仿vscode暗黑主题 效果图 设置方式(把主题代码复制进来即可) 是基于雅蓝主题自定义的 设置好后需要切换到雅蓝主题 hbuilderx保存时自动整理代码 1.首先在顶部栏,找到工具,打开设置 2.点击旁边的编…

uniapp做微信小程序,自定义checkbox和radio的样式

用uniapp做个微信小程序,其中有用到自定义checkbox和radio的样式;代码记录如下: 自定义checkbox 在App.vue中写入样式: checkbox.red .wx-checkbox-input,checkbox.red .uni-checkbox-input {background-image: url(/static/ima…

MySQL锁定:死锁及其避免方法

文章目录 一、MySQL锁定和并发控制的重要性二、MySQL锁机制回顾2.1 锁类型:共享锁和排他锁2.2 锁粒度:行级锁和表级锁 三、死锁的原因和场景四、检测和解决死锁4.1 死锁检测算法4.2 死锁处理策略4.3 手动处理死锁 五、死锁的预防和避免分布式环境下&…

驱动程序设计 利用RTC显示年月日时分秒到终端 7.11

驱动控制RTC 用户需求:写一个RTC时钟控制的驱动,实现RTC显示年月日时分秒到用户端 驱动需求:设备:RTC模块 功能:打印显示 寄存器操作: 原理图: 设备–>pin–>设备控制芯片 ​ 驱动需求 …

信号波形时序图常用工具推荐

Refer: 下载:画时序图的四大神器_可编程器件-面包板社区 (eet-china.com) 软件工程师,习惯使用StarUML画Timing Diagram, 硬件工程师建议使用一下软件。 1、AndyTiming 免费的,这个有一个知乎的博文可以参考 https://zhuanlan.zhihu.com/p…