前言:目前Redis相关的知识内容已经成为后端面试的考核常客了,掌握并理解Redis可以为你的面试大大加分哦,另外想要在面试中脱颖而出,靠死记硬背标准答案是不可取的。在本系列中,小黑板将会以面试为导向,串联起Redis的相关知识,帮助大家在面试中牢牢抓住面试官的小心心~
话不多说,我们直接进入正题!我们循序渐进地模拟一下真实的面试场景,读者朋友们也可以尝试作答,看看面对面试官的“拷问”,你会给出怎样的回答。
Q1:我看你的简历上写的有用过redis,那你能大概讲一下你了解哪些东西吗?或者讲一下你对redis的认识也行
分析:这个问题就是最常见的热身问题了,但是也不可小觑,因为你回答的内容会作为接下来面试官的主要切入点,所以一定要回答自己掌握的内容,你可以不全了解,但是需要保证你提到的点是你能够讲清楚的,这一点非常重要!并且建议分点作答,会显得更加有条理性,是很大的加分项!
A:好的,Redis的话其实有着非常丰富的使用场景,比如可以缓存、排行榜啊、共同关注列表啊之类的场景下都可以使用Redis
那其实提到redis首先会有几个特点让我印象比较深刻:
- 第一点,redis是单线程的
- 第二点,redis是基于内存的,速度非常快
- 第三点,redis提供了丰富的数据结构
分析:一般来说回答出以上几点就可以很好的为面试官提供切入点了,面试是一个互动的过程,如何将面试官引入你预先设计好的“陷阱”中是一门学问,只要准备好了,不怕你问,就怕你不问,嘿嘿~
Q2:你提到了Redis是单线程的,那它为什么这么快?
分析:这个问题算是redis面试中的高频问题了,那么如何回答上来的同时体现自己的思考就非常重要了。因为面试官这个问题可能已经问了几十个人了,如果你也按照所谓的标准答案来作答,那样的话是无法给面试官留有深刻印象的哦。回答这个问题首先要讲清楚Redis的单线程到底指的是什么?其实是Redis的核心模块是单线程的,并不是全部都是单线程的,此外,Redis6.0是支持多线程的,这一点能讲出来其实就是加分项了,说明你有自主学习的驱动力。其次,需要说明核心模块是单线程的,那么redis是怎么保证速度的,按照这个思路分点回答,并进行拓展即可。
A:Redis的单线程指的其实是指执行Redis命令的核心模块是单线程的,也就是文件事件处理器,主要由四个部分组成:套接字、IO多路复用、文件事件分派器和事件处理器
并且Redis6.0其实已经支持多线程来提高性能了。而Redis之所以快主要原因有三点
- 第一,Redis是基于内存的,数据都存放在内存中,速度非常快
- 第二,Redis的IO模型是非阻塞IO
- 第三,Redis核心模块的单线程使得可以避免线程切换带来的开销
Q3:既然聊到了IO,那你说一下你对IO模型的了解吧,了解哪些IO模型?详细说一下?
分析:IO模型的问题同样是面试常客,大部分同学在面试的时候可能就会回答IO模型有阻塞IO、非阻塞IO、IO多路复用之类的,然后把概念一摆,两手一摊,给面试官的感觉就是你在着跟我背课文呢。这样的面试自然取得不到好的效果,还是那句话,**面试官希望听到的回答中需要有你自己的思考和总结,**这样你的回答才具有一定的区分度,很多同学对于同步阻塞、同步非阻塞IO这些概念性的东西非常的迷糊,其实没有那么难,看下去就知道了
A:实际上IO的过程主要包含了两个阶段
-
第一阶段,等待数据准备好
-
第二阶段,将数据从内核空间拷贝到应用程序地址空间
根据这两个阶段的不同表现来将IO进行分类:
- 在第一个阶段阻塞即为阻塞IO,不阻塞直接返回则为非阻塞IO
- 在第二个阶段阻塞则为同步IO,不阻塞则为异步IO
- 多路复用IO其实是通过轮询机制来负责多个socket
补充:关于同步阻塞IO、同步非阻塞IO、异步IO、IO多路复用等很多初学者理解起来比较困难,而网络上的文章质量又参差不齐,很容易误导读者,后面贴心的小黑板会专门写一篇关于IO的文章,帮助大家在面试中轻松应对这道考题
Q4:既然Redis是单线程的,那么它如何利用多核呢?
A:可以通过开启多个Redis实例来利用多核
根据你抛出的前两点,其实常问的问题差不多就是这样,重头戏其实在第三点,Redis的数据结构部分。既有基础数据结构如hash、list、set等,同样有高级数据结构Hyperlogger、布隆过滤器等等。
这些数据结构的用法以及底层原理和实现经常会在面试过程中被问到,回答好的话是非常亮眼的加分项,在下一回合的交锋中,面试官又会如何针对这些知识点进行考查呢?在回答这些问题的时候又有哪些套路呢?
欲知后事如何,欢迎大家点点手指关注小黑板哦~