位置: 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)

  • iphone怎么恢复微信删除的聊天记录(苹果手机如何恢复微信聊天)

    iphone怎么恢复微信删除的聊天记录(苹果手机如何恢复微信聊天)

  • 苹果6怎么升级iOS13(iphone 6怎么升级)

    苹果6怎么升级iOS13(iphone 6怎么升级)

  • i5-7200u属于什么水平(i57200u属于什么档次的处理器)

    i5-7200u属于什么水平(i57200u属于什么档次的处理器)

  • 微信收款简报可以消除记录吗(微信收款简报顾客管理怎么删除)

    微信收款简报可以消除记录吗(微信收款简报顾客管理怎么删除)

  • 苹果京东自营旗舰店是苹果授权的吗(苹果京东自营旗舰店)

    苹果京东自营旗舰店是苹果授权的吗(苹果京东自营旗舰店)

  • 酷狗音乐hd是什么意思(酷狗音乐hd2265)

    酷狗音乐hd是什么意思(酷狗音乐hd2265)

  • 网易云直播粉团怎么掉了(网易云粉团是什么意思)

    网易云直播粉团怎么掉了(网易云粉团是什么意思)

  • 怎么把朋友的微信名片发给别人(怎么把朋友的微信转到朋友圈)

    怎么把朋友的微信名片发给别人(怎么把朋友的微信转到朋友圈)

  • ipad pro 12.9一代和二代区别(ipad pro12.9一代充电功率)

    ipad pro 12.9一代和二代区别(ipad pro12.9一代充电功率)

  • 打电话没声音怎么回事(打电话没声音怎么办?11)

    打电话没声音怎么回事(打电话没声音怎么办?11)

  • word中粗箭头怎么打(word粗剪头)

    word中粗箭头怎么打(word粗剪头)

  • 苹果官方升级到ios13(iphone官网升级)

    苹果官方升级到ios13(iphone官网升级)

  • 手机怎么开空调(手机怎么开空调万能遥控器华为)

    手机怎么开空调(手机怎么开空调万能遥控器华为)

  • ps变黑白快捷键(ps变黑白快捷键看黑白关系)

    ps变黑白快捷键(ps变黑白快捷键看黑白关系)

  • 小米社区有什么用(小米社区有什么方法快速提升成长值)

    小米社区有什么用(小米社区有什么方法快速提升成长值)

  • 苹果x卡了什么原因(苹果x手机为什么卡)

    苹果x卡了什么原因(苹果x手机为什么卡)

  • 华为mate20por指纹在哪(华为mate20por指纹会闪线)

    华为mate20por指纹在哪(华为mate20por指纹会闪线)

  • oppoa5密码忘了怎么办(oppoa5密码忘了怎么样解锁不恢复出厂设置)

    oppoa5密码忘了怎么办(oppoa5密码忘了怎么样解锁不恢复出厂设置)

  • 原彩显示在哪里(苹果原彩显示在哪里)

    原彩显示在哪里(苹果原彩显示在哪里)

  • 无法接听电话请留言是什么意思(无法接听电话请留言是挂了吗)

    无法接听电话请留言是什么意思(无法接听电话请留言是挂了吗)

  • 新华三路由器怎么设置(新华三路由器怎么登录)

    新华三路由器怎么设置(新华三路由器怎么登录)

  • oppor17多重(oppor17机身重量)

    oppor17多重(oppor17机身重量)

  • Win10新版21364发布: 可直接运行Linux图形程序

    Win10新版21364发布: 可直接运行Linux图形程序

  • CentOS利用telnet命令检测IP端口的命令方法(centos8 telnet)

    CentOS利用telnet命令检测IP端口的命令方法(centos8 telnet)

  • Logstash 入门实战(4)--filter plugin 介绍(logstash gsub)

    Logstash 入门实战(4)--filter plugin 介绍(logstash gsub)

  • 公司有买社保就要交税吗
  • 核定征收企业所得税率是多少
  • 亏损企业如何填报企业所得税
  • 教培行业提成一般多少
  • 白酒赠品赠什么方案
  • 劳务公司如何避税与避费
  • 政府补助应计入
  • 工资薪金总额包括年终奖吗
  • 企业零申报怎么申报
  • 建筑业未开票收入情况说明
  • 非独立核算的分公司可以开票吗
  • 预付款期末有结余年末如何做账务处理?
  • 印花税少提了怎么办
  • 关于公司食堂的文案
  • 水利建设基金2021
  • 扩建费用
  • 金蝶标准版年末已经结账如果重新结账
  • 营业外支出汇算清缴调增填哪
  • 利润表中财务费用可以为负数吗
  • 白酒消费税最低计税价格
  • 纳税人申领发票流程
  • 以前年度资产损失,汇算清缴怎么填表
  • 增值税专用发票丢了怎么补救
  • 局域网的工作模式及特点
  • php实现分页功能的方法
  • 职工教育经费超过可以结转以后年度怎么做账
  • 核定征收印花税的文件
  • 在建工程转无形资产 会计准则
  • 多模态教学模式论文
  • 31.JavaScript数组进阶,一网打尽数组操作函数slice、filter、map、reduce、some、every、find、splice
  • php页面跳转可以用header
  • 累计折旧大白话
  • 增值税申报表填错不影响税额
  • 装修公司开的劳务发票
  • 个人账户收到多少钱会被监控
  • 织梦系统
  • phpcms v9网页禁止复制
  • 企业主营业务收入净额怎么算
  • sql server 2008打开界面
  • 小规模个体工商户怎么交税
  • 营运资金周转率是什么指标
  • 委托加工物资的消费税计入成本吗
  • 销售原材料的差价怎么算
  • 未达账项审计调账怎么办
  • 银行贷款直接给钱吗
  • 个体工商户要进行汇算清缴吗
  • 委外加工半成品入库的会计分录
  • 银行代扣水电费发票到哪里打
  • 一年以内到期的长期借款属于
  • 食品加工企业成本核算方法和流程
  • mysql必知必会读后感2000字
  • mysql数据类型decimal
  • sql server高级应用
  • 数据库汉字转拼音
  • 域怎么改名
  • open bsd
  • freenas11.2安装教程
  • win10无人值守文件使用方法
  • window10重启按什么键
  • mac如何中文输入法
  • Ghost XP SP3电脑市场专业装机版 V5.5
  • windows10如何设置windows7开始菜单
  • linux升级内核要重启吗
  • linux git管理工具
  • jquery鼠标点击
  • jsonp实现动态加载文件
  • 用bat打开cmd执行命令
  • bat脚本ftp上传文件
  • android studio报错
  • unity3d官方教程
  • js中的tostring方法
  • Javascript字符串奇数位替换
  • jquery跨域请求有哪些方式
  • 砂石需要缴纳资源税吗
  • 河南城乡居民医疗保险电话
  • 信息技术税务分类编码
  • 北京税务局地税电话
  • 专利转让个人所得税转换为经营所得
  • 出口退税账户标识是否怎么选
  • 乡镇经管站是如何工作
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设