转自:http://www.dewen.org/q/971/memcache%E5%92%8Credis%E6%9C%AC%E8%B4%A8%E5%8C%BA%E5%88%AB%E5%9C%A8%E5%93%AA%E9%87%8C%EF%BC%9F

7个答案 票 数
何远伦
4 票
何远伦8673
1.Redis中,并不是所有的数据都一直存储在内存中的,这是和Memcached相比一个最大的区别。

2.Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,hash等数据结构的存储。

3.Redis支持数据的备份,即master-slave模式的数据备份。

4.Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。

我个人认为最本质的不同是Redis在很多方面具备数据库的特征,或者说就是一个数据库系统,而Memcached只是简单的K/V缓存

何远伦 编辑于 2012-01-10
评论 (1) • 链接 • 2012-01-10
0
这么比起来,redis完胜啊 – kazaff 2012-09-10
薛帮书
3 票
薛帮书724
Schema MySQL: 需事先设计 Memcached: 无需设计 Redis: 小型系统可以不用,但是如果要合理的规划及使用Redis,需要事先进行类似如下一些规划 数据项: value保存的内容是什么,如用户资料 Redis数据类型: 如String, List 数据大小: 如100字节 记录数: 如100万条(决定是否需要拆分)
上面的规划就是一种schema,为什么Redis在大型项目需要事先设计schema?因为Redis服务器有容量限制,数据容量不能超出物理内存大 小,同时考虑到业务数据的可扩充性,记录数会持续增多、单条记录的内容也都会增长,因此需要提前规划好容量,数据架构师就是通过schema来判断当前业 务的Redis是否需要“分库分表”以满足可扩展需求。
2. 容量及带宽规划
容量规划
MySQL: < 硬盘大小
Memcached: < RAM
Redis: < RAM
带宽规划
由于Redis比MySQL快10倍以上,因此带宽也是需要事先规划,避免带宽跑满而出现瓶颈。
3. 性能规划(QPS)
当系统读写出现瓶颈,通常如何解决?
MySQL
写: 拆分到多服务器
读: (1) 拆分 (2) 写少也可以通过增加Slave来解决
Memcached
读写: 都通过hash拆分到更多节点。
Redis:
写:拆分
读: (1) 拆分 (2) 写少也可以通过增加Slave来解决
4. 可扩展性
MySQL: 分库分表
Memcached: hash分布
Redis:也可以分库,也可以hash分布
小结
通过以上分析,Redis在很多方面同时具备MySQL及Memcached使用特征,在某些方面则更像MySQL。
由于Redis数据不能超过内存大小,一方面需要进行事先容量规划,保证容量足够;另外一方面设计上需要防止数据规模无限制增加,进而导致Redis不可扩展。
Redis需要象MySQL一样预先设计好拆分方案。

评论 (0) • 链接 • 2012-01-17
天地一指
3 票
天地一指409
现在新浪微博大规模的都是基于redis来架构的。
redis和memecache的不同在于:
1、存储方式:
memecache 把数据全部存在内存之中,断电后会挂掉,数据不能超过内存大小
redis有部份存在硬盘上,这样能保证数据的持久性。
2、数据支持类型:
redis在数据支持上要比memecache多的多。
3、使用底层模型不同:
新版本的redis直接自己构建了VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求。
4、运行环境不同:
redis目前官方只支持LINUX 上去行,从而省去了对于其它系统的支持,这样的话可以更好的把精力用于本系统 环境上的优化,虽然后来微软有一个小组为其写了补丁。但是没有放到主干上

评论 (1) • 链接 • 2012-01-17
0
VM不是废弃了么。 – magic 2012-01-17
magic
1 票
magic1563
memcache是cache;
redis是db,更像mongodb。

评论 (0) • 链接 • 2012-01-10
jimmy
1 票
jimmy140
memcache只能当做缓存,cache
redis的内容是可以落地的,就是说跟mongodb有些类似,然后redis也可以作为缓存,并且可以设置master-slave

评论 (0) • 链接 • 2012-02-13
wayne173
0 票
wayne17356
其实就是重启后会不会数据丢失。
memcache 存在内存中,分配的内存满后,会按一定的规则删除一些k/v数据,重启后自然全部丢失。
redis 是分两部分的,有一部分是近期使用的会放到内存中,但是他的数据是全部存储在磁盘上的,可以持久化,服务器遇到重启情况,数据很快可以恢复使用。

评论 (0) • 链接 • 2012-07-11
jerrysearch
0 票
jerrysearch45
我认为本质的区别就是两种nosql实现对于事务性操作的支持不同,memcache为了实现数据一致性采用了一种乐观锁的思想,导致其在数据插入时很浪费资源,所以memcache性能全面低于redis

评论 (0) • 链接 • 2012-09-13

转载于:https://www.cnblogs.com/jiajinyi/p/3530180.html

memcache和redis本质区别在哪里?相关推荐

  1. php多选批量修改数据库数据类型有哪些_php面试题之memcache和redis的区别

    这篇文章介绍的内容是关于php面试题六之memcache和redis的区别,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 Memcache和Redis区别: * Redis中,并不是所 ...

  2. Redis、Memcache和MongoDB的区别

    >>Memcached Memcached的优点: Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key.value的字节大小以及服务器硬件性能,日常环 ...

  3. Ehcache、memcache、redis三大缓存区别

    Ehcache.memcache.redis三大缓存区别 最近项目组有用到这三个缓存,去各自的官方看了下,觉得还真的各有千秋!今天特意归纳下各个缓存的优缺点,仅供参考! Ehcache 在java项目 ...

  4. Py西游攻关之RabbitMQ、Memcache、Redis

    Py西游攻关之RabbitMQ.Memcache.Redis RabbitMQ 解释RabbitMQ,就不得不提到AMQP(Advanced Message Queuing Protocol)协议. ...

  5. PHP面试常考内容之Memcache和Redis(2)

    你好,是我琉忆. 继周一(2019.2-18)发布的"PHP面试常考内容之Memcache和Redis(1)"后,这是第二篇,感谢你的支持和阅读. 本周(2019.2-18至2-2 ...

  6. 浅析Memcache和Redis

    想必开发的小伙伴们对Memcache和Redis都不陌生吧,最近正好在整理它们,于是就写一下博客吧!一方面是分享,另一方面便于自己查找. 首先,来说说Memcache和Redis是什么? 说得简单一点 ...

  7. memcache、Redis与MongoDB的学习-1

    除此接触这三个词的概念,对今天看的资料最了一些整理. 之前经常有看到memcache.Redis与MongoDB相关的数据库,最开始意味这些都只是用来做数据库优化的缓存工具,后来具体看了一些资料之后才 ...

  8. 网站缓存技术总结( ehcache、memcache、redis对比)

    网站技术高速发展的今天,缓存技术已经成为大型网站的一个关键技术,缓存设计好坏直接关系的一个网站访问的速度,以及购置服务器的数量,甚至影响到用户的体验. 网站缓存按照存放的地点不同,可以分为客户端缓存. ...

  9. 数据库工作笔记016---Redis、Memcache和MongoDB的区别

    技术交流QQ群[JAVA,.NET,BigData,AI]:170933152 了解一下还是有必要滴,要不然光知道用一个也不行啊,逮住一个一直用不行,都得捣鼓捣鼓 >>Memcached ...

最新文章

  1. ASP.NET Core 2.2中的Endpoint路由
  2. 是什么限制了我对Graphical abstract的想象力
  3. 新浪微博授权失败:applications over the unaudited use restrictions
  4. poj1738 an old stone game
  5. Procedure execution failed 2013 - Lost connection to MySQL server during query
  6. Walking Robot
  7. 洛谷 - P3975 [TJOI2015]弦论(后缀自动机)
  8. HDU - 4705 Y(树形dp)
  9. C/C++的readdir和readdir_r函数(遍历目录)
  10. 计算机视觉论文-2021-07-16
  11. Linux文件句柄占用数量查看与设置
  12. JVM Learning Note 4 -- HotSpot JVM Options List
  13. 神经网络学习笔记(1)——神经元与激活函数简介
  14. SQL:查询各科成绩前三名
  15. 2019年世界500强完整榜单,出炉!
  16. 微软2016校园招聘4月在线笔试2-403 Forbidden
  17. 如果你恨一个人,把他送到北京,那是地狱;如果你爱一个人,也送他送到北京,那是天堂...
  18. 太秀了!用Pandas秒秒钟搞定24张Excel报表,还做了波投放分析!
  19. 浅析LRU(K-V)缓存
  20. python selenium移动端网页下拉刷新

热门文章

  1. 【java】数组异常的处理
  2. 【java】创建一个顶层框架类的对象
  3. css中调整高度充满_css - DIV高度怎样充满容器?
  4. 如何开启outlook邮箱的pop3和smtp_怎么在电子邮件客户端上登录腾讯邮箱(QQ邮箱 )?
  5. Python如何在循环语句中加入两个变量_Python基础知识
  6. 信息收集之域名、IP互查
  7. 实现可拖拽,拉伸,吸附功能的甘特图(时间/任务表)
  8. 《计算机系统:核心概念及软硬件实现(原书第4版)》——1.4数据库系统
  9. 第二章 Javac编译原理
  10. Android 来电归属地显示功能demo