Redis的常见面试题

目录

前言

Redis支持哪些数据类型

五种核心类型 

Zset为什么用跳表不用红黑树 ?

Redis常见的应用场景? 

 如何检测Redis的连通性?

如何设置key的过期时间? 

Redis为什么是单线程模型? 

Redis里的IO多路复用是什么? 

RDB的持久化机制有哪些? 

AOF的重写机制是怎么样的? 

 Redis的过期删除策略是怎么样的?

Redis处理缓存雪崩的问题:

Redis的主从复制是怎么回事?

 介绍一下Redis哨兵

 Redis集群是干什么用的?

Redis的哈希槽是怎么回事? 

Redis集群会有操作丢失吗? 

 如何理解Redis的事务?和MySQL的事务有什么区别?

什么是缓存穿透、缓存雪崩、缓存击穿 

缓存穿透

缓存雪崩

缓存击穿

 Redis和MySQL如何保证双写一致性?

 Redis的“bigkey”问题


前言

Redis是一个高性能的key-value的内存数据库 ,在内存上的数据会随着掉电而通通消失,所以就有了不同的持久化的方式(搞到硬盘上)。Redis没有关系型数据库那种复杂查询的功能,而换来的是简单易用和高性能~~

Redis支持哪些数据类型

五种核心类型 

  • String
  • Hashmap
  • List
  • Set
  • Zset 

 后续新增了一些数据类型~

  • Bitmap:通过二进制位表示某个数是否存在
  • Bitfield:把字符串当作位图,进行位操作
  • Hyperloglog:基于位图实现计数效果
  • Geospatial:地理信息,存储经纬度,并可以进行一些空间计算
  • Stream:消息队列

Zset为什么用跳表不用红黑树 ?

跳表的插入、删除、查询的时间复杂度一样是O(logN),与红黑树一样。但是跳表更简单,不需要重新平衡这种操作

Redis常见的应用场景? 

  • 缓存:用来保存常见的热点数据,减少数据库的压力
  • 计数器:统计点击次数、收藏、点赞次数等
  • 排行榜:可以基于Zset简单实现
  • 分布式会话:使用Redis存储会话信息,可以让用户访问到系统的不同模块的时候都使用同一个公共会话
  • 分布式锁:对于分布式的一种并发控制手段,可以基于Redis来实现,上篇文章有详细展开
  • 消息队列:Redis自身支持Stream数据类型,可以作为简单的消息队列使用

 如何检测Redis的连通性?

给服务端发送一个 "ping" ,通顺的话就会收到 "pong" 

如何设置key的过期时间? 

可以在set key的时候通过EX选项指定过期时间,也可以再使用expire对已存在的key设置过期时间 

Redis为什么是单线程模型? 

Redis内部逻辑较为简单,大部分的性能瓶颈都是出现在IO或内存上,很少是CPU。因此使用多线程还没多大收益,还容易引入线程安全问题

从Redis6.0开始,Redis引入多线程,此时它也只是使用多线程去处理网络请求+协议解析,真正执行Redis命令的仍然是单线程完成,这样可以提高IO处理效率 

Redis里的IO多路复用是什么? 

 Redis主要是基于Linux提供的epoll机制来完成IO多路复用(之前文章详细讲述过)

所谓IO多路复用,其实就是一个线程来管理多个 socket ,并按需激活线程

|  假如在同一个单位时间内,有多个Redis客户端的请求到来了.....

使用传统的方式是给每一个客户端连接开一个线程,但是大部分的客户端不会频繁的给你      传输,即多数是空闲线程(不活跃) , 所以搞一堆线程不如就用一个线程来处理,反正并    发量不会太高而且处理速度又飞快

上述的操作被Linux封装好了,就是IO多路复用

在Linux中有三种实现方式:

  • select
  • poll
  • epoll

epoll是最新,也是最高效的版本(之前文章有详细讲述)这里浅浅谈一下

epoll在内核维护了一个红黑树,来管理这些socket,并且每一个节点都关联了一个事件回调,当系统内核感知到网卡收到数据,进一步判定这个数据是给哪一个socket的,随之调用对应的回调函数,进一步唤醒用户线程,来处理这个数据

RDB的持久化机制有哪些? 

 RDB和AOF两种

RDB:

  • RDB是一个紧凑的二进制文件,代表Redis某个时间的数据快照。适合备份,全量复制的场景。
  • Redis加载RDB文件来恢复数据远快于AOF
  • 但是RDB也没办法做到实时持久化。因为每次的bgsave都需要fork,全量复制对于cpu和硬盘的负荷大
  • 此外,RDB文件使用特定的二进制格式保存,Redis版本演进过程中有多个RDB版本,兼容性可能有冲突

 AOF:

  • AOF记录所有写入Redis的命令(文本方式),因此AOF的实时性高,适合在Redis宕机的时候恢复
  • AOF提供了重写功能,可以定期对AOF文件进行重写,取出冗余命令,减小AOF大小
  • 由于每次的命令都要同步到AOF文件中,所以会有一定的写入延迟
  • AOF文件是文本类型的数据比较大
  • 如果AOF的文件过大就会导致恢复速度比较慢了

AOF的重写机制是怎么样的? 

  1.  Redis在后台启动一个AOF重写进程
  2.  在AOF重写过程中,Redis继续处理客户端请求,并将这份数据同时保存到旧AOF文件以及一个缓冲区
  3. 新的AOF文件会遍历内存中的数据状态,只保留数据的最后状态。并与缓冲区共同生成一份完整的AOF文件
  4. 用新的AOF文件来代替旧的AOF文件

 Redis的过期删除策略是怎么样的?

惰性过期

只有当访问一个key的时候才能判断他是否过期,过期就清除。

这种策略方式可以节省CPU资源,但是会有可能出现大量过期的key未被再次访问,导致占用大量内存

定期过期

每个一段时间,会扫描一定数量的数据库expires字典中一定数量的key,并清除已过期的key。

expire字典中会保存所有设置了过期时间的key的过期时间数据,其中key是指向某个键的指针,value是该键的毫秒精度的UNIX时间戳表示过期时间

 Redis中则是同时使用了这两种策略:

  • 每隔100ms就随机抽取一定数量的key来检查和删除
  • 在获取key的时候检查一下是否过期,过期就删除

Redis处理缓存雪崩的问题:

首先对于定期删除来说,Redis会注册一个定时器,每个一定时间就触发一次

在删除的时候会根据事先统计好的过期key的个数来决定后续策略

如果过期key的个数超过总key的25%,就会让Redis持续删除过期key直到最大删除时间(默认25ms),但即使如此,有些对性能要求高的常见仍然会因为阻塞25ms导致性能下降

解决方案:可以在过期时间上加上随机值,使过期时间分散一点,降低触发这个25%阈值

Redis的主从复制是怎么回事?

 其实就是为了保证咱redis的高可用减少单个节点的负载(具体流程之前文章讲述过)

Redis主从复制icon-default.png?t=N7T8https://blog.csdn.net/Obto_/article/details/135946296

 介绍一下Redis哨兵

之前文章有详细讲述,感兴趣的可以看看这篇文章
Redis哨兵icon-default.png?t=N7T8https://blog.csdn.net/Obto_/article/details/135964383

Redis Sentinel是Redis的高可用的实现方案,在实际的生产环境中,对整个系统的高可用提升是非常有帮助的,当主从复制结构中某个节点宕机之后,哨兵能够自动发现故障并完成故障转移

如果是主节点故障,哨兵之中会互相协商(哨兵不只一个),当大多数哨兵节点达成主节点宕机的结果后,就会在哨兵之中推举出一个领导节点来自动完成故障转转移的工作,同时将这个变化通知给Redis客户端,这个过程是全自动的不需要人工介入

 Redis集群是干什么用的?

 之前的文章有详细讲述,感兴趣的可以看看这篇文章

Redis集群icon-default.png?t=N7T8https://blog.csdn.net/Obto_/article/details/136176895

Redis集群引入多组Master/Slave,每一组Master/Slave存储数据全集的一部分,从而构成更大的整体,解决单个Master/Slave能够达到的性能上限,能够存储更多的数据

好比一个30T的资源放在一个硬盘放不下,就可以放在3个10T的硬盘上 

 

Redis的哈希槽是怎么回事? 

在Redis集群中要合理的分配各个主节点的资源,所以就有了不同的hash方式将数据映射到对应的分片中

第一种就是直接hash 一个 N ,N为分片的总数,这样能够保证数据随机分配,但是一旦出现数据扩容的情况,N发生了变化,此时之前的映射关系全部作废,扩容的代价很大

第二种就是一致性hash,统一hash一个数,这样能解决上述因扩容而导致的映射关系被破坏,但是会导致数据的不均匀

因此哈希槽分区算法就出来了

哈希槽分区算法:

将所有的key都映射到16284(2^14) 个槽位上,再把这些槽均匀的分配给每个分片,每个分片只需要记录自己拥有哪些槽位即可 (详细的连接在上面Redis集群链接中)

 

Redis集群会有操作丢失吗? 

Redis并不能保证数据的强一致性,实际中集群在特定的条件下可能会丢失写操作

比如在成功写入一个key之后,正好主节点宕机,那么此时由于这个数据还未来得及同步到从节点,也没来得及写入AOF日志,就会丢失

 

 如何理解Redis的事务?和MySQL的事务有什么区别?

区别:

  • 弱原子性
  • 不保证一致性
  • 不需要隔离性
  • 不需要持久化 

Redis事务的本质就是在服务器搞了一个“事务队列”,每次客户端进行操作的时候,就先把命令保存在事务队列中,收到EXEC命令后才会一起执行

Redis事务和MySQL事务的概念上是一样的,都是把一系列的操作捆绑成一组,让一组批量执行

 

什么是缓存穿透、缓存雪崩、缓存击穿 

缓存穿透

访问的key不存在客户端也不存在服务端,此时这样的key就不被缓存起来,而高频的访问这个不存在的key就会导致Redis失去他“保护盾”的作用

解决办法:

1.布隆过滤器

2.将不存在的key也存在redis并随便设置value为'.'

3.对需要查询的key进行严格的合法性校验,不合规的不让查

缓存雪崩

短时间内大量的key 在缓存上失效,导致数据库压力暴增

解决方法:

1.部署高可用的Redis集群

2.不给key设置时间,或设置时间的时候添加随机时间因子

缓存击穿

相当于缓存血崩的特殊情况,就是针对热点key过期了,导致大量的请求访问到了MySQL上

解决方法:

1.基于统计的方式发现热点key,并设置永不过期

2.进行必要的服务降级,访问数据的时候使用分布式锁,限制并发数

 Redis和MySQL如何保证双写一致性?

什么是“双写一致性” ??

当用户修改数据的时候,需要修改数据库,同时也要更新缓存中的数据 

如果直接写数据库并写Redis,此时万一有一方写入失败,就容易出现数据不一致情况

解决方法:

方案一:延迟双删

1.删除缓存数据

2.更新数据库

3.再删除缓存数据

方案二:删除缓存重试

1.先删除缓存数据,如果失败,就把失败的key放到一个mq中,稍后进行重试

 

 Redis的“bigkey”问题

指的就是key对应的value很大占据较大的存储空间

可以使用redis-cli --bigkey查找bigkey,删除bigkey尽量不要用del,用unlink在后台删

这样的big可以会导致读写的时候性能下降,如果是集群分配部署,也会引起不同分片的数据倾斜

解决方案:

核心思路就是拆分,将大key拆成多个小key,每个key对应value的一部分数据 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

恶意代码识别率提升95%!谷歌开源人工智能网络安全防御工具

近日,谷歌日前宣布发起网络安全人工智能防御计划,旨在利用人工智能技术提升网络安全水平,扭转困扰网络安全行业的“防守困境”。 该计划的核心举措是开源Magika,这是一款用于文件类型识别的AI工具,能够帮助检测恶意软件…

国产嵌入式教学实验箱操作教程:2-13 定时器控制实验

一、实验目的 熟悉定时器的基本结构,学习定时器的功能和控制方法,并实现基于定时器中断方式控制程序。 二、实验原理 定时器 TMS320CC6748有4个定时器/计数器,均可配置为64位计数器、两个独立32位计数器及自动重装32位计数器,…

【FreeRTOS基础入门】事件组与同步点

文章目录 前言一、事件组是什么案例1.1 事件组的概念 二、事件组的操作2.1 事件组与其他实现同步与互斥方法的区别2.2 创建事件组2.3 删除事件组2.4 设置事件2.5 等待事件2.6 示例代码 三、同步点3.1 同步点是什么3.2 设置同步点 总结 前言 FreeRTOS是一个广泛应用于嵌入式系统…

我的第一个浏览器插件网页一键上传的开发历史

前言 一键上传选中的网页内容,实现知识快速收藏。如飞书剪存,有道云剪报,MrDoc速记。早在2008年,我参考了有道云一键上传,实现了一个简单的浏览器插件,能方便保存网页内容到个人网站。这些插件目前都很难兼…

Day32 进程Process

文章目录 1.什么是进程1.1 概念1.2 特点1.3 进程段1.4 进程分类1.5 进程状态1.6 进程状态切换图1.7 调度进程 2.进程函数接口2.1 创建进程 fork()2.2 回收资源函数2.3 结束进程2.4 获取进程号 3.exec函数族(了解)4.守护进程 Daemon4.1 守护进程的特点4.2…

提升技术栈的秘诀:Spring Cloud学习网站带你飞跃职业瓶颈!

介绍:Spring Cloud是一个基于Spring Boot实现的微服务架构开发工具集。 Spring Cloud利用Spring Boot的开发便利性简化了分布式系统基础设施的开发。例如,服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等都是其内置的功能。它的优势包括…

LangChain支持哔哩哔哩视频总结

是基于LangChain框架下的开发,所以最开始请先 pip install Langchain pip install bilibili-api-python 技术要点: 使用Langchain框架自带的Document loaders 修改BiliBiliLoader的源码,自带的并不支持当前b站的视频加载 源码文件修改&a…

前端架构: 实现脚手架终端UI样式之ANSI escape code, Chalk, Ora介绍

在脚手架当中实现命令行的UI显示 1 )概述 在命令行中,如果想实现除传统的常规文本以外的内容比如想对字体进行加粗斜体下划线,包括对它改变颜色改变前景色改变后景色等等需要借助一个叫做 ANSI escape code 这样的一个概念它其实是一个标准&…

文献速递:GAN医学影像合成--基于生成对抗网络的肺部图像分类的多域医学图像翻译生成

文献速递:GAN医学影像合成–基于生成对抗网络的肺部图像分类的多域医学图像翻译生成 01 文献速递介绍 在2019年底,一种称为2019冠状病毒病(COVID-19)的新型冠状病毒肺炎出现,迅速成为全球性大流行。感染COVID-19可以…

18.贪心算法

排序贪心 区间贪心 删数贪心 统计二进制下有多少1 int Getbit_1(int n){int cnt0;while(n){nn&(n-1);cnt;}return cnt; }暴力加一维前缀和优化 #include <iostream> #include <climits> using namespace std; #define int long long const int N2e510; in…

热门游泳耳机哪个牌子好,吐血整理全网高口碑机型!

近年来&#xff0c;游泳已经成为众多人们喜爱的运动项目之一。而在游泳过程中&#xff0c;许多人希望能够享受到音乐的陪伴&#xff0c;以增加运动的乐趣。然而&#xff0c;由于阻力、防水和水压等问题&#xff0c;传统的耳机并不能满足游泳者的需求。因此&#xff0c;在市面上…

基于JAVA+SpringBoot+Vue的前后端分离的电子商城

✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取项目下载方式&#x1f345; 一、项目背景介绍&#xff1a; 在当今数字化时代&…

bat判断vmware 是否已安装

要通过批处理脚本&#xff08;.bat&#xff09;判断VMware是否已安装&#xff0c;您可以尝试以下方法&#xff1a; 检查VMware的进程 您可以检查VMware相关的进程是否在运行。例如&#xff0c;VMware Workstation的进程名通常是vmware-workstation.exe。 echo off tasklist /…

计网 - 域名解析的工作流程

文章目录 Pre引言1. DNS是什么2. 域名结构3. 域名解析的工作流程4. 常见的DNS记录类型5. DNS安全6. 未来的发展趋势 Pre 计网 - DNS 域名解析系统 引言 在我们日常使用互联网时&#xff0c;经常会输入各种域名来访问网站、发送电子邮件或连接其他网络服务。然而&#xff0c;我…

【命令行工具kubectl】

如何在k8s的任意节点使用用kubectl # 正常在node节点上是无法执行kubectl命令 [rootk8s-node-01 ~]# kubectl get pods The connection to the server localhost:8080 was refused - did you specify the right host or port?1、将master节点中/etc/kubernetes/,admin.conf拷…

性能分析5部曲:瓶颈分析与问题定位,如何快速解决瓶颈?

一、引言 很多做性能测试的同学都问过我这样一个问题&#xff1a;鱼哥(Carl_奕然)&#xff0c;你说性能测试的重点是什么? 我的回答很简单&#xff1a;瓶颈分析与问题定位。 在性能项目的整个周期&#xff0c;不管是脚本设计&#xff0c;脚本编写还是脚本执行&#xff0c;都…

fastjson解析自定义get方法导致空指针问题

背景 为了在日志中把出入参打印出来&#xff0c;以便验证链路和排查问题&#xff0c;在日志中将入参用fastjson格式化成字符串输出&#xff0c;结果遇到了NPE。 问题复现 示例代码 public static void main(String[] args) {OrganizationId orgId new OrganizationId();N…

Nginx -2

接着上文写 5.4.7 验证模块 需要输入用户名和密码 模块名称&#xff1a;ngx_http_auth_basic_module 访问控制基于模块 ngx_http_auth_basic_module 实现&#xff0c;可以通过匹配客户端资源进行限制 语法&#xff1a; Syntax: auth_basic string | off; Default: auth_ba…

RK3568平台开发系列讲解(Linux系统篇)编写I2C客户端驱动程序

🚀返回专栏总目录 文章目录 一、定义和注册I2C驱动程序二、在设备树中实例化I2C设备——新方法三、总结沉淀、分享、成长,让自己和他人都能有所收获!😄 配置I2C设备基本上分为两个步骤。 定义并注册I2C驱动程序定义并注册I2C设备在DT中,I2C设备属于非存储器映射设备系列…

MySQL报错:sql_mode=only_full_group_by解决方法

Linux环境 ubuntu 22.04 MySQL是8.0.35版本 问题描述 Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column auth_system.t_class_temp_config.id which is not functionally dependent on columns in GROUP BY clause; this is inco…