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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 转载地址:http://gnucto.blog.51cto.com/3391516/998509 Redis与Me...
    Ddaidai阅读 21,504评论 0 82
  • 分布式缓存技术PK:选择Redis还是Memcached? 经平台同意授权转载 作者:田京昆(腾讯后台研发工程师)...
    meng_philip123阅读 69,007评论 7 60
  • 本文将从Redis的基本特性入手,通过讲述Redis的数据结构和主要命令对Redis的基本能力进行直观介绍。之后概...
    kelgon阅读 61,438评论 23 625
  • 我上小学时,我爸是黑池塬村上的民办教师,记得那时学校条件很差,就像现在我们在网上看到的图片一样:小娃们坐的是砖...
    军玲阅读 3,704评论 0 2
  • 很热。 树上的叶子绿得,发油。 还真是绿油油的。 走在石板小路上, 看着路边的小树和路边的路边的大树, 小树还在贪...
    藜绾辞阅读 1,396评论 0 0

友情链接更多精彩内容