Redis与Memcached的比较

  1. 网络IO模型

    Memcached是多线程,非阻塞IO复用的网络模型,分为监听主线程和worker子线程,监听线程监听网络连接,接受请求后,将连接描述字pipe 传递给worker线程,进行读写IO, 网络层使用libevent封装的事件库,多线程模型可以发挥多核作用,但是引入了cache coherency和锁的问题,比如,Memcached最常用的stats 命令,实际Memcached所有操作都要对这个全局变量加锁,进行计数等工作,带来了性能损耗。

    (Memcached网络IO模型)

    Redis使用单线程的IO复用模型,自己封装了一个简单的AeEvent事件处理框架,主要实现了epoll、kqueue和select,对于单纯只有IO操作来说,单线程可以将速度优势发挥到最大,但是Redis也提供了一些简单的计算功能,比如排序、聚合等,对于这些操作,单线程模型实际会严重影响整体吞吐量,CPU计算过程中,整个IO调度都是被阻塞住的。

  2. 内存管理方面

    Memcached使用预分配的内存池的方式,使用slab和大小不同的chunk来管理内存,Item根据大小选择合适的chunk存储,内存池的方式可以省去申请/释放内存的开销,并且能减小内存碎片产生,但这种方式也会带来一定程度上的空间浪费,并且在内存仍然有很大空间时,新的数据也可能会被剔除,原因可以参考Timyang的文章:http://timyang.net/data/Memcached-lru-evictions/

    Redis使用现场申请内存的方式来存储数据,并且很少使用free-list等方式来优化内存分配,会在一定程度上存在内存碎片,Redis跟据存储命令参数,会把带过期时间的数据单独存放在一起,并把它们称为临时数据,非临时数据是永远不会被剔除的,即便物理内存不够,导致swap也不会剔除任何非临时数据(但会尝试剔除部分临时数据),这点上Redis更适合作为存储而不是cache。

  3. 数据一致性问题

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

  4. 存储方式及其它方面

    Memcached基本只支持简单的key-value存储,不支持枚举,不支持持久化和复制等功能

    Redis除key/value之外,还支持list,set,sorted set,hash等众多数据结构,提供了KEYS

    进行枚举操作,但不能在线上使用,如果需要枚举线上数据,Redis提供了工具可以直接扫描其dump文件,枚举出所有数据,Redis还同时提供了持久化和复制等功能。

  5. 关于不同语言的客户端支持

    在不同语言的客户端方面,Memcached和Redis都有丰富的第三方客户端可供选择,不过因为Memcached发展的时间更久一些,目前看在客户端支持方面,Memcached的很多客户端更加成熟稳定,而Redis由于其协议本身就比Memcached复杂,加上作者不断增加新的功能等,对应第三方客户端跟进速度可能会赶不上,有时可能需要自己在第三方客户端基础上做些修改才能更好的使用。

根据以上比较不难看出,当我们不希望数据被踢出,或者需要除key/value之外的更多数据类型时,或者需要落地功能时,使用Redis比使用Memcached更合适。

来源:http://blog.chinaunix.net/uid-26111972-id-3420130.html

Redis与Memcached的比较相关推荐

  1. 常用的高性能 KV 存储 Redis、Memcached、etcd、Zookeeper 区别

    1. 什么是 KV 存储 KV 是 Key-Value 的缩写,KV 存储也叫键值对存储.简单来说,它是利用 Key 做索引来实现数据的存储.修改.查询和删除功能. 常用的高性能 KV 存储主要有 R ...

  2. Key-Value数据库:Redis与Memcached之间如何选择?

    华为云分布式缓存Redis5.0和Memcached都是华为云DCS的核心产品. 那么在不同的使用场景之下,如何选择Redis5.0和Memcached呢? 就由小编为大家进行详细的数据对比分析吧 R ...

  3. Mongo、Redis、Memcached对比及知识总结

    存储原理(持久化) Mongo Mongo的数据将会保存在底层文件系统,因此存储容量远大于redis和memcached.一个database中所有的collections以及索引信息会分散存储在多个 ...

  4. 相比Redis,Memcached真的过时了吗?

    下面内容来自Redis作者在stackoverflow上的一个回答,对应的问题是<Is memcached a dinosaur in comparison to Redis?>(相比Re ...

  5. Redis与Memcached简要比较

    2019独角兽企业重金招聘Python工程师标准>>> 如果简单地比较Redis与Memcached的区别,大多数都会得到以下观点: 1 Redis不仅仅支持简单的k/v类型的数据, ...

  6. oracle定时器定时删除30天前的数据_Redis-数据淘汰策略持久化方式(RDB/AOF)Redis与Memcached区别...

    Redis与Memcached区别: 两者都是非关系型数据库.主要有以下不同: 数据类型: Memcached仅支持字符串类型. redis支持:String,List,set,zset,hash 可 ...

  7. redis 和 memcached 有什么区别?redis 的线程模型是什么?为什么 redis 单线程却能支撑高并发?...

    这个是问 redis 的时候,最基本的问题吧,redis 最基本的一个内部原理和特点,就是 redis 实际上是个单线程工作模型, 你要是这个都不知道,那后面玩儿 redis 的时候,出了问题岂不是什 ...

  8. Redis和Memcached,干货来一波

    1.数据类型支持不同 与Memcached仅支持简单的key-value结构的数据记录不同,Redis支持的数据类型要丰富得多.最为常用的数据类型主要由五种:String.Hash.List.Set和 ...

  9. Redis 和 Memcached 的区别

    来源:标点符 链接:http://www.biaodianfu.com/redis-vs-memcached.html Redis 的作者 Salvatore Sanfilippo 曾经对这两种基于内 ...

  10. redis和Memcached的区别,都什么时候使用?

    redis和Memcached的区别,都什么时候使用? 缓存在互联网公司占得比例还是蛮大的,提到缓存呢,就一定会想到redis和memcache,现在绝大多数的公司呢,都是推荐使用redis,这是为什 ...

最新文章

  1. apache workprefork
  2. BCH比特币现金有何魅力,让“比特币耶稣”和矿工们都看涨买入?
  3. Flutter组件学习(二)—— Image
  4. mysql开源内库_MySQL数据库(查询语句)
  5. iOS开发 字符串的转化 小技巧
  6. DockOne微信分享(一一零):Docker在沪江落地的实践
  7. java list 转json 字符串_fastjson将java list转为json字符串
  8. typedef定义结构体数组类型
  9. 使用 Fabric CA 生成 MSP
  10. 高精度ua级恒流源_一种高精度可调恒流源电路的制作方法
  11. Win10系统下怎么开启管理员administrator权限?
  12. 使用ale-import-roms导入atari的rom时RuntimeError问题解决办法
  13. 《仗剑啸江湖》技术支持
  14. 微信可上线类型与封杀理由
  15. 动态Probit模型及Stata实现
  16. 加密流量分析-4.加密协议分析
  17. 【乐逍遥网站设计】网站建设费用都有哪些组成?
  18. 【长句分析】2019.7.25
  19. iOS开发- Xcode插件- 规范凝视生成器VVDocumenter 自己的见解
  20. 基于Andriod的连锁药店管理系统APP-计算机毕业设计

热门文章

  1. 如何实现把固定内容自动写入excel_Excel如何把修改记录自动写入批注?
  2. 标签的宽度_27 表格标签
  3. Flink状态管理与CheckPoint、Savepoint
  4. 关于Maven中的常见命令,通过命令的方式快速创建一个空的maven工程,将jar包打到maven仓库中
  5. JFinal开发环境搭建,JFinal开发案例
  6. 使用POI读取excel文件内容
  7. Apache 与tomcat实现分布式应用部署
  8. 比特币地址可以查到本人吗_查看每一个地址有多少个比特币
  9. 学习Caffe(二)使用Caffe:Caffe加载模型+Caffe添加新层+Caffe finetune
  10. 颜色排序(Sort Colors)