位置: IT常识 - 正文

Redis 被问麻了...(redis常见问题解决)

编辑:rootadmin
Redis 被问麻了...

推荐整理分享Redis 被问麻了...(redis常见问题解决),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:redis遇到的问题,redisdao,redis常见问题解决,redis被攻击,redis quene,redis quene,redis quene,redis quene,内容如对您有帮助,希望把文章链接给更多的朋友!

Redis是面试中绕不过的槛,只要在简历中写了用过Redis,肯定逃不过。今天我们就来模拟一下面试官在Redis这个话题上是如何一步一步深入,全面考察候选人对于Redis的掌握情况。

小张:

面试官,你好。我是来参加面试的。

面试官:

你好,小张。我看了你的简历,熟练掌握Redis,那么我就随便问你几个Redis相关的问题吧。首先我的问题是,Redis是单线程还是多线程呢?

小张:

Redis不同版本之间采用的线程模型是不一样的,在Redis4.0版本之前使用的是单线程模型,在4.0版本之后增加了多线程的支持。

在4.0之前虽然我们说Redis是单线程,也只是说它的网络I/O线程以及Set 和 Get操作是由一个线程完成的。但是Redis的持久化、集群同步还是使用其他线程来完成。

4.0之后添加了多线程的支持,主要是体现在大数据的异步删除功能上,例如 unlink key、flushdb async、flushall async 等

面试官:

回答的很好,那为什么Redis在4.0之前会选择使用单线程?而且使用单线程还那么快?

小张:

选择单线程个人觉得主要是使用简单,不存在锁竞争,可以在无锁的情况下完成所有操作,不存在死锁和线程切换带来的性能和时间上的开销,但同时单线程也不能完全发挥出多核CPU的性能。

至于为什么单线程那么快我觉得主要有以下几个原因:

Redis 的大部分操作都在内存中完成,内存中的执行效率本身就很快,并且采用了高效的数据结构,比如哈希表和跳表。

使用单线程避免了多线程的竞争,省去了多线程切换带来的时间和性能开销,并且不会出现死锁。

采用 I/O 多路复用机制处理大量客户端的Socket请求,因为这是基于非阻塞的 I/O 模型,这就让Redis可以高效地进行网络通信,I/O的读写流程也不再阻塞。

面试官:

不错,那Redis是如何实现数据不丢失的呢?

小张:

Redis数据是存储在内存中的,为了保证Redis数据不丢失,那就要把数据从内存存储到磁盘上,以便在服务器重启后还能够从磁盘中恢复原有数据,这就是Redis的数据持久化。Redis数据持久化有三种方式。

AOF 日志(Append Only File,文件追加方式):记录所有的操作命令,并以文本的形式追加到文件中。

RDB 快照(Redis DataBase):将某一个时刻的内存数据,以二进制的方式写入磁盘。

混合持久化方式:Redis 4.0 新增了混合持久化的方式,集成了 RDB 和 AOF 的优点。

面试官:

那你分别说说 AOF和 RDB的实现原理吧。

小张:

AOF采用的是写后日志的方式,Redis先执行命令把数据写入内存,然后再记录日志到文件中。AOF日志记录的是操作命令,不是实际的数据,如果采用AOF方法做故障恢复时需要将全量日志都执行一遍。

RDB采用的是内存快照的方式,它记录的是某一时刻的数据,而不是操作,所以采用RDB方法做故障恢复时只需要直接把RDB文件读入内存即可,实现快速恢复。

面试官:

你刚提到了AOF采用的是 “写后日志” 的方式,我们平时用的MySQL则采用的是 “写前日志”,那 Redis为什么要先执行命令,再把数据写入日志呢?

小张:额头开始冒汗,问的是些啥问题呀。。。

额,这个主要是由于Redis在写入日志之前,不对命令进行语法检查,所以只记录执行成功的命令,避免出现记录错误命令的情况,而且在命令执行后再写日志不会阻塞当前的写操作。

面试官:

那 后写日志又有什么风险呢?

小张:

我... 这个我不会。

面试官:

好吧,后写日志主要有两个风险可能会发生:

数据可能会丢失:如果 Redis 刚执行完命令,此时发生故障宕机,会导致这条命令存在丢失的风险。

可能阻塞其他操作:AOF 日志其实也是在主线程中执行,所以当 Redis 把日志文件写入磁盘的时候,还是会阻塞后续的操作无法执行。

我还有个问题是 RDB做快照时会阻塞线程吗?

Redis 被问麻了...(redis常见问题解决)

小张:

Redis 提供了两个命令来生成 RDB 快照文件,分别是 save 和 bgsave。save 命令在主线程中执行,会导致阻塞。而 bgsave 命令则会创建一个子进程,用于写入 RDB 文件的操作,避免了对主线程的阻塞,这也是 Redis RDB 的默认配置。

面试官:

RDB 做快照的时候数据能修改吗?

小张:

save是同步的会阻塞客户端命令,bgsave的时候是可以修改的。

面试官:

那Redis是怎么解决在bgsave做快照的时候允许数据修改呢?

小张:(你咋还问。。。我™不会啊!)

额,这个我不太清楚...

面试官:

这里主要是利用bgsave的子线程实现的,具体操作如下:

如果主线程执行读操作,则主线程和 bgsave 子进程互相不影响;

如果主线程执行写操作,则被修改的数据会复制一份副本,然后 bgsave子进程会把该副本数据写入 RDB 文件,在这个过程中,主线程仍然可以直接修改原来的数据。

要注意,Redis 对 RDB 的执行频率非常重要,因为这会影响快照数据的完整性以及 Redis 的稳定性,所以在 Redis 4.0 后,增加了 AOF 和 RDB 混合的数据持久化机制: 把数据以 RDB 的方式写入文件,再将后续的操作命令以 AOF 的格式存入文件,既保证了 Redis 重启速度,又降低数据丢失风险。

小张:

学到了学到了。

面试官:

那你再跟我说说Redis如何实现高可用吧?

小张:

Redis实现高可用主要有三种方式:主从复制、哨兵模式,以及 Redis 集群。

主从复制

将从前的一台 Redis 服务器,同步数据到多台从 Redis 服务器上,即一主多从的模式,这个跟MySQL主从复制的原理一样。

哨兵模式

使用 Redis 主从服务的时候,会有一个问题,就是当 Redis 的主从服务器出现故障宕机时,需要手动进行恢复,为了解决这个问题,Redis 增加了哨兵模式(因为哨兵模式做到了可以监控主从服务器,并且提供自动容灾恢复的功能)。

Redis Cluster(集群)

Redis Cluster 是一种分布式去中心化的运行模式,是在 Redis 3.0 版本中推出的 Redis 集群方案,它将数据分布在不同的服务器上,以此来降低系统对单主节点的依赖,从而提高 Redis 服务的读写性能。

面试官:

使用哨兵模式在数据上有副本数据做保证,在可用性上又有哨兵监控,一旦master宕机会选举salve节点为master节点,这种已经满足了我们的生产环境需要,那为什么还需要使用集群模式呢?

小张:

额,哨兵模式归根节点还是主从模式,在主从模式下我们可以通过增加salve节点来扩展读并发能力,但是没办法扩展写能力和存储能力,存储能力只能是master节点能够承载的上限。所以为了扩展写能力和存储能力,我们就需要引入集群模式。

面试官:

集群中那么多Master节点,redis cluster在存储的时候如何确定选择哪个节点呢?

小张:

这应该是使用了某种hash算法,但是我不太清楚。。。

面试官:

那好,今天的面试就到这里吧,你先回去等我们的面试通知。

小张:

好的,谢谢面试官,你能告诉我redis cluster怎么实现节点选择的吗?

面试官:

Redis Cluster采用的是类一致性哈希算法实现节点选择的,至于什么是一致性哈希算法你自己回去看看。

Redis Cluster将自己分成了16384个Slot(槽位),哈希槽类似于数据分区,每个键值对都会根据它的 key,被映射到一个哈希槽中,具体执行过程分为两大步。

根据键值对的 key,按照 CRC16 算法计算一个 16 bit 的值。

再用 16bit 值对 16384 取模,得到 0~16383 范围内的模数,每个模数代表一个相应编号的哈希槽。

每个Redis节点负责处理一部分槽位,加入你有三个master节点 ABC,每个节点负责的槽位如下:

节点处理槽位A0-5000B5001 - 10000C10001 - 16383

这样就实现了cluster节点的选择。

本文链接地址:https://www.jiuchutong.com/zhishi/299975.html 转载请保留说明!

上一篇:5个前端练手项目(html css js canvas)(哪里能找到前端练手项目教程)

下一篇:jeesite 定时任务 或者springboot 执行定时任务(定时任务java)

  • 荣耀hjc-lx9是什么型号呢(荣耀9x型号hlkal00)

    荣耀hjc-lx9是什么型号呢(荣耀9x型号hlkal00)

  • 华为nova7se怎么设置24小时制(华为nova7se怎么截屏长图)

    华为nova7se怎么设置24小时制(华为nova7se怎么截屏长图)

  • 虚拟机连接不上网络(虚拟机连接不上finalshell)

    虚拟机连接不上网络(虚拟机连接不上finalshell)

  • 小米平衡车保修期多久(小米平衡车保修几年)

    小米平衡车保修期多久(小米平衡车保修几年)

  • 华为畅享10s的语音助手怎么打开(华为畅享10s语音唤醒功能在哪里设置)

    华为畅享10s的语音助手怎么打开(华为畅享10s语音唤醒功能在哪里设置)

  • 刚办一天的电话卡能注销吗(昨天办了电话卡,今天想取消可以吗)

    刚办一天的电话卡能注销吗(昨天办了电话卡,今天想取消可以吗)

  • 抖音二维码图片怎么扫(抖音二维码图片加好友)

    抖音二维码图片怎么扫(抖音二维码图片加好友)

  • 手机有时候有声音有时候没声音是怎么回事(手机有时候有声音有时候没声音是什么问题)

    手机有时候有声音有时候没声音是怎么回事(手机有时候有声音有时候没声音是什么问题)

  • qq备份软件叫什么(qq备份工具)

    qq备份软件叫什么(qq备份工具)

  • 耳机接口type c是什么意思(耳机接口类型 typec)

    耳机接口type c是什么意思(耳机接口类型 typec)

  • 电源适配器损坏的表现(电源适配器损坏原因及对策)

    电源适配器损坏的表现(电源适配器损坏原因及对策)

  • 小米10要贴膜吗(小米10要贴手机膜吗)

    小米10要贴膜吗(小米10要贴手机膜吗)

  • 华为手机能用两个电信卡吗(华为手机能用两个卡吗)

    华为手机能用两个电信卡吗(华为手机能用两个卡吗)

  • 苹果watch能录音吗(苹果watch录音如何导出)

    苹果watch能录音吗(苹果watch录音如何导出)

  • iphone7是几核处理器(苹果7是几核)

    iphone7是几核处理器(苹果7是几核)

  • 七天网络登录显示未授权(七天网络无法登陆怎么办)

    七天网络登录显示未授权(七天网络无法登陆怎么办)

  • 红米note7pro是什么屏幕(红米note7pro优点和缺点)

    红米note7pro是什么屏幕(红米note7pro优点和缺点)

  • 淘宝愿望清单有什么用(淘宝心愿清单是干什么的)

    淘宝愿望清单有什么用(淘宝心愿清单是干什么的)

  • 苹果a13芯片有多快(苹果a13芯片有多重啊)

    苹果a13芯片有多快(苹果a13芯片有多重啊)

  • 苹果充电自动断电(苹果充电自动断电功能)

    苹果充电自动断电(苹果充电自动断电功能)

  • vivoz3x返回键在哪里(vivoz3i手机怎么调出返回键)

    vivoz3x返回键在哪里(vivoz3i手机怎么调出返回键)

  • 韵达快递怎么用手机号查询(韵达快递怎么用手机号码查询)

    韵达快递怎么用手机号查询(韵达快递怎么用手机号码查询)

  • iphone有没有呼吸灯(苹果自带的呼吸软件)

    iphone有没有呼吸灯(苹果自带的呼吸软件)

  • 微信显示手机号怎么设置(微信显示手机号没有注册是怎么回事)

    微信显示手机号怎么设置(微信显示手机号没有注册是怎么回事)

  • 屏幕时间管理怎么取消(屏幕时间管理怎么关闭)

    屏幕时间管理怎么取消(屏幕时间管理怎么关闭)

  • form表单提交数据如何拿到返回值(form表单提交数组)

    form表单提交数据如何拿到返回值(form表单提交数组)

  • 适用综合所得税率表
  • 土地增值税的计算方法公式
  • 运输行业一般纳税人税率
  • 以前年度损益调整结转到未分配利润
  • 坏账准备应计入
  • 社保基数变更上限怎么办
  • 购买金税盘抵扣
  • 2019年定额手撕发票2023年还能用吗
  • 闲置设备折旧企业所得税税前扣除
  • 劳务派遣营改增政策
  • 2020年减免水利基金会计分录
  • 不开发票的收入如何申报纳税
  • 当月费用没结账的能先预估计提吗?
  • 发票已抵扣是什么意思
  • 出口企业是外贸企业吗
  • 海关补料
  • 专利申请费用怎么做账
  • 实收资本印花税最新政策2023年
  • 小微企业季度所得税怎么计算
  • 向员工发放用餐费的通知
  • 小规模开税票怎么开
  • 怎样冲回多提应收账款?
  • 本年利润结转到利润分配是每月都结转还是年底结转
  • 企业有哪些资金结构
  • 营销策划费用计算公式
  • windows为什么从7开始
  • 建筑工程购买的家用清洁电器能勾选认证吗
  • 加计扣除的会计要素
  • php函数function
  • php bcmul
  • 入门易学
  • php中file
  • idea如何运行ssm项目spring
  • bestars皮纳
  • php进程数设置
  • 盒子模型的概念
  • 常用的css样式有哪些
  • 小规模升级一般纳税人需要多久
  • 餐饮营改增什么时候开始的
  • 银行贷款第三方是什么意思
  • 酒店维修费是计入销售成本吗
  • 预扣预缴和汇算清缴是什么意思
  • 总资产报酬率的高低直接影响净资产收益率的高低
  • 普通发票为什么只能领一张
  • 企业重组后的债权怎么处理
  • 软件开发并销售产品
  • 贷款利息进项税为什么不能抵扣
  • 财务费用利息属于什么科目
  • 一般纳税人支付房租账务处理
  • 疫情期间公司购买物品
  • 取得投资款缴纳企业所得税吗
  • 用友t3固定资产反结账的操作步骤
  • 营业外收入的账户结构
  • 保本理财产品如何赎回
  • 机票抵扣怎么填申报表
  • 颁发数字证书要符合什么条件
  • 特许权使用费代扣代缴企业所得税
  • 销售退货怎么开票
  • mysql日期用什么数据类型
  • sql转换
  • sql中nullif
  • centos怎么看硬盘
  • ubuntu查看内存占用最多的进程ID
  • windows 7磁盘
  • win7任务栏窗口总是自动切换
  • 微软新品什么时候上市
  • Serv-U 构建个人FTP服务器图解
  • win7无线网络连接不上怎么解决方法
  • 如何win10
  • win8系统如何备份系统
  • win8怎么没有无线网图标不见了
  • window系统设置
  • 原生js实现路由
  • 对于javascript理解
  • 怎么优化项目
  • python的math模块只有pass
  • javascript要怎么学
  • 江西省国家税务局总局官网
  • 金税盘注销后怎么开发票
  • 进项发票勾选认证如何导出明细
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设