Redis面试常用会问到的一些问题 (一)

Redis面试常用会问到的一些问题 (一)

  • 一).redis和memcached有什么区别?redis的线程模型是什么?为什么单线程的redis比多线程的memcached效率要高得多(为什么redis是单线程的但是还可以支撑高并发)?
    • 首先咱们说区别
      • 这个事儿吧,你可以比较出N多个区别来,但是我还是采取redis作者给出的几个比较吧
    • Redis的线程模型
    • 为啥Redis单线程模型也能效率那么高

一).redis和memcached有什么区别?redis的线程模型是什么?为什么单线程的redis比多线程的memcached效率要高得多(为什么redis是单线程的但是还可以支撑高并发)?

首先咱们说区别

这个事儿吧,你可以比较出N多个区别来,但是我还是采取redis作者给出的几个比较吧

(1).Redis支持服务器端的数据操作:Redis相比Memcached 来说,拥有更多的数据结果和并支持更多的数据库操作,通常在Memcached里,你需要将数据拿到客户端进行类似的修改再set 回去。这大大的增加了网络IO的次数和数据体积。 在Redis众,这些复杂的操作通常和一半的GET/Set一样高效。如果需要缓存能够支持更多的复杂的结构和操作,那么Redis会是个不错的选择。

(2).内存使用效率对比:使用简单的key-value存储的话,Memcached内存利用率更高,而如果Redis采用hash结构来做key-value存储,由于其组合式的压缩,内存利用率会高于Memcached。

(3).性能对比:由于Redis只使用单核,而Memcached可以使用多核,所以平均每一个核上Redis在存储小数据时比Memcached性能更高。而在100k以上的数据中,Memcached性能要高于Redis,虽然Redis最近也在存储大数据的性能上进行优化,但是比起Memcached,还是稍有逊色

(4).集群模式:memcached没有原生的集群模式,需要依靠客户端来实现往集群中分片写入数据;但是redis目前是原生支持cluster模式的,redis官方就是支持redis cluster集群模式的,比memcached来说要更好

Redis的线程模型

Redis的线程图

为啥Redis单线程模型也能效率那么高

1)纯内存操作
2)核心是基于非阻塞的IO多路复用机制
3)单线程反而避免了多线程的频繁上下文切换问题(百度)

你可能感兴趣的:(Redis)