支持的数据类型
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文件中加载相应数据,然后再返回给请求方。