前言:目前 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、布隆过滤器等等。
这些数据结构的用法以及底层原理和实现常常会在面试过程中被问到,答复好的话是十分亮眼的加分项,在下一回合的交锋中,面试官又会如何针对这些知识点进行考查呢?在答复这些问题的时候又有哪些套路呢?
欲知后事如何,欢送大家点点手指关注小黑板哦~