Redis相关面试题

记录一下自己总结相关的Redis八股文

一、为什么要使用Redis作为缓存,而不用本地缓存呢?

1:Redis作为一个第三方框架,具有很好的水平扩展性,且在多个服务项目中,如果只是用本地缓存,那么会造成有些服务有缓存,而有些服务无缓存,从而导致频繁的查询数据库,降低用户体验

2:Redis支持AOF和RDB两种持久化方式,从而使得缓存数据得以保存,防止丢失某些重要的数据

3:Redis提供了很多高效的数据结构对数据进行操作,如压缩表、跳表、哈希表等等

4:Redis是单线程模型, 因为是单线程模型,减少了线程之间的上下文切换,提升了效率

二、为什么后来Redis 6.0要引入多线程模型呢?

Redis6.0之后,Redis变为一个主线程和多个其它线程,主线程用于接收命令,然后交给其它线程取解析这些命令, 其它线程将命令解析完毕后,提交给主线程执行命令

所以说:虽然引入了多个线程,当实际上执行命令的还是主线程这一个线程

三、说一说Redis的Hash扩容机制?

整体上Redis使用的是与Java1.8以前HashMap相关的数据结构,就是数组+链表的形式,当然Redis在扩容的时候有些许不同,同样是在到达某个阈值之后,数组就会进行扩容,此时Redis会创建一个新的数组,然后使用渐进式ReHash的方式对数组进行扩容,这样的好处在于执行扩容的时候没必要对全部数组进行转移,只有等需要的时候才将原数组的部分数据转移到新数组中,先但与用空间换时间的方式,虽然增大了空间消耗,但是减少了时间消耗

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值