Memcached和Redis比较

支持的数据类型

Memcached只能存储K-V型数据
redis除了支持K-V型数据,还支持list、set、hash、zset

数据备份

redis支持master-slave形式的数据备份,Memcached不支持数据备份。

持久化

redis支持两种持久化方案:RDB(快照)和AOF(追加日志)。

  • RDB方式的优点占用空间小,缺点是如果在下次快照前系统崩溃,会丢失一部分数据。
  • AOF方式的优点是不容易丢失数据,缺点是日志文件占用空间大,经常需要自动压缩。
    Memcached不支持持久化。

网络IO模型

  • Memcached是多线程、非阻塞IO复用的模型,一个监听主线程来接收客户端的请求,多个worker子线程进行IO读写。网络层使用libevent封装的事件库,多线程可以更好的利用多核资源,并发性更好,但是引入了缓存一致性(cache coherency)和锁的问题。比如,Memcached最常用的stats 命令,实际Memcached所有操作都要对这个全局变量加锁,进行计数等工作,带来了性能损耗。
  • Redis使用单线程的IO复用模型,自己封装了一个简单的AeEvent事件处理框架,主要实现了epoll、kqueue和select,对于单纯只有IO操作来说,单线程可以将速度优势发挥到最大,但是Redis也提供了一些简单的计算功能,比如排序、聚合等,对于这些操作,单线程模型实际会严重影响整体吞吐量,计算过程中,整个IO调度都是被阻塞住的。

内存管理

Memcached采用预分配内存池的方式,优点是降低了申请释放内存的开销,确定是导致空间浪费和内存碎片。
redis采用现场分配内存的方式。一定程度上也会导致内存碎片。

数据一致性

Memcached提供了cas命令,可以保证多个并发访问操作同一份数据的一致性问题。 Redis没有提供cas 命令,并不能保证这点,不过Redis提供了事务的功能,可以保证一串 命令的原子性,中间不会被任何操作打断。

一个误区

redis并不是将所有的数据都一直存储在内存中的。这是和Memcached相比一个最大的区别。有一个阈值,当内存使用量超过这个阈值后,将触发swap的操作,Redis根据“swappability = age*log(size_in_memory)”计 算出哪些key对应的value需要swap到磁盘。然后会将这些value持久化到磁盘上,同时内存中只保存key,清除value。当请求数据时,如果key对应的value不在内存中,那么Redis就需要从swap文件中加载相应数据,然后再返回给请求方。

    原文作者:码农也越野
    原文地址: https://www.jianshu.com/p/82721e265e46
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞