记录一下自己总结相关的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的方式对数组进行扩容,这样的好处在于执行扩容的时候没必要对全部数组进行转移,只有等需要的时候才将原数组的部分数据转移到新数组中,先但与用空间换时间的方式,虽然增大了空间消耗,但是减少了时间消耗