从以下几个维度,对 redis、memcache、mongoDB 做了对比。 
1、性能 
都比较高,性能对我们来说应该都不是瓶颈。 
总体来讲,TPS 方面 redis 和 memcache 差不多,要大于 mongodb。 
2、操作的便利性 
memcache 数据结构单一。(key-value) 
redis 丰富一些,数据操作方面,redis 更好一些,较少的网络 IO 次数,同时还提供 list,set, 
hash 等数据结构的存储。 
mongodb 支持丰富的数据表达,索引,最类似关系型数据库,支持的查询语言非常丰富。 
3、内存空间的大小和数据量的大小 
redis 在 2.0 版本后增加了自己的 VM 特性,突破物理内存的限制;可以对 key value 设置过 
期时间(类似 memcache) 
memcache 可以修改最大可用内存,采用 LRU 算法。Memcached 代理软件 magent,比如建立 
10 台 4G 的 Memcache 集群,就相当于有了 40G。 magent -s 10.1.2.1 -s 10.1.2.2:11211 -b 
10.1.2.3:14000 mongoDB 适合大数据量的存储,依赖操作系统 VM 做内存管理,吃内存也比较厉害,服务 
不要和别的服务在一起。 
4、可用性(单点问题) 
对于单点问题, 
redis,依赖客户端来实现分布式读写;主从复制时,每次从节点重新连接主节点都要依赖整 
个快照,无增量复制,因性能和效率问题, 
所以单点问题比较复杂;不支持自动 sharding,需要依赖程序设定一致 hash 机制。 
一种替代方案是,不用 redis 本身的复制机制,采用自己做主动复制(多份存储),或者改成 
增量复制的方式(需要自己实现),一致性问题和性能的权衡 
Memcache 本身没有数据冗余机制,也没必要;对于故障预防,采用依赖成熟的 hash 或者环 
状的算法,解决单点故障引起的抖动问题。 
mongoDB 支持 master-slave,replicaset(内部采用 paxos 选举算法,自动故障恢复),auto sharding 机制,对客户端屏蔽了故障转移和切分机制。 
5、可靠性(持久化) 
对于数据持久化和数据恢复, 
redis 支持(快照、AOF):依赖快照进行持久化,aof 增强了可靠性的同时,对性能有所影 
响 
memcache 不支持,通常用在做缓存,提升性能; 
MongoDB 从 1.8 版本开始采用 binlog 方式支持持久化的可靠性 
6、数据一致性(事务支持) 
Memcache 在并发场景下,用 cas 保证一致性redis 事务支持比较弱,只能保证事务中的每个操作连续执行 
mongoDB 不支持事务 
7、数据分析 
mongoDB 内置了数据分析的功能(mapreduce),其他不支持 
8、应用场景 
redis:数据量较小的更性能操作和运算上 
memcache:用于在动态系统中减少数据库负载,提升性能;做缓存,提高性能(适合读多写 
少,对于数据量比较大,可以采用 sharding) 
MongoDB:主要解决海量数据的访问效率问题。 
表格比较: 
memcache redis 类型 内存数据库 内存数据库 
数据类型 在定义 value 时就要固定数据类型 不需要 
有字符串,链表,集 合和有序集合 
虚拟内存 不支持 支持 
过期策略 支持 支持 
分布式 magent master-slave,一主一从或一主多从 
存储数据安全 不支持 使用 save 存储到 dump.rdb 中 
灾难恢复 不支持 append only file(aof)用于数据恢复 
性能 
1、类型——memcache 和 redis 都是将数据存放在内存,所以是内存数据库。当然,memcache 也可用于缓存其他东西,例如图片等等。 
2、 数据类型——Memcache 在添加数据时就要指定数据的字节长度,而 redis 不需要。 
3、 虚拟内存——当物理内存用完时,可以将一些很久没用到的 value 交换到磁盘。 
4、 过期策略——memcache 在 set 时就指定,例如 set key1 0 0 8,即永不过期。Redis 可以通 
过例如 expire 设定,例如 expire name 10。 
5、 分布式——设定 memcache 集群,利用 magent 做一主多从;redis 可以做一主多从。都可 
以一主一从。 
6、 存储数据安全——memcache 断电就断了,数据没了;redis 可以定期 save 到磁盘。 
7、 灾难恢复——memcache 同上,redis 丢了后可以通过 aof 恢复。 
Memecache 端口 11211 
yum -y install memcached 
yum -y install php-pecl-memcache 
/etc/init.d/memcached start memcached -d -p 11211 -u memcached -m 64 -c 1024 -P /var/run/memcached/memcached.pid 
-d 启动一个守护进程 
-p 端口 
-m 分配的内存是 M 
-c 最大运行并发数-P memcache 的 pid 
//0 压缩(是否 MEMCACHE_COMPRESSED) 30 秒失效时间 
//delete 5 是 timeout

redis、memcache、mongoDB 对比的更多相关文章

  1. Redis,Memcache,mongoDB的区别

    从以下几个维度,对redis.memcache.mongoDB 做了对比,欢迎拍砖 1.性能 都比较高,性能对我们来说应该都不是瓶颈 总体来讲,TPS方面redis和memcache差不多,要大于mo ...

  2. HBase、Redis、MongoDB、Couchbase、LevelDB主流 NoSQL 数据库的对比

    最近小组准备启动一个 node 开源项目,从前端亲和力.大数据下的IO性能.可扩展性几点入手挑选了 NoSql 数据库,但具体使用哪一款产品还需要做一次选型. 我们最终把选项范围缩窄在 HBase.R ...

  3. redis、memcached、mongoDB 对比与安装

    一.redis.memcached.mongoDB 对比 Memcached 和 Redis都是内存型数据库,数据保存在内存中,通过tcp直接存取,速度快,并发高.Mongodb是文档型的非关系型数据 ...

  4. Redis.Memcache和MongoDB区别?

    Memcached的优势: Memcached可以利用多核优势,单吞吐量极高,可以达到几十万QPS(取决于Key.value的字节大小以及服务器硬件性能,日常环境中QPS高峰大约在4-6w左右.)适用 ...

  5. Redis和Memcache性能测试对比

    Redis和Memcache在写入性能上面差别不大,读取性能上面尤其是批量读取性能上面Memcache全面胜出,当然Redis也有自己的优点:比如数据持久化.支持更多的数据结构(Set List ZS ...

  6. Redis与Memcached对比

    Redis是一种高级key-value数据库.它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富,有字符串.链表.集合和有序集合.支持在服务器端计算集合的并,交和补集等.还支持多 ...

  7. Redis和MongoDB的区别(面试受用)

    项目中用的是MongoDB,但是为什么用其实当时选型的时候也没有太多考虑,只是认为数据量比较大,所以采用MongoDB. 最近又想起为什么用MongoDB,就查阅一下,汇总汇总: 之前也用过redis ...

  8. redis和mongodb的比较

    >>RedisRedis的优点:支持多种数据结构,如 string(字符串). list(双向链表).dict(hash表).set(集合).zset(排序set).hyperloglog ...

  9. redis memcache 比较

    Redis与Memcached的区别 传统MySQL+ Memcached架构遇到的问题 实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都 ...

  10. Redis和MongoDB的区别以及应用场景

    Redis和MongoDB的区别以及应用场景 项目中用的是MongoDB,但是为什么用其实当时选型的时候也没有太多考虑,只是认为数据量比较大,所以采用MongoDB. 最近又想起为什么用MongoDB ...

随机推荐

  1. 最小高度的树 Minimum Height Trees

    2018-09-24 12:01:38 问题描述: 问题求解: 毫无疑问的一条非常好的题目,采用的解法是逆向的BFS,也就是从叶子节点开始遍历,逐步向中心靠拢,最终留下的叶子节点就是答案. publi ...

  2. (转+整理)C#中动态执行代码

    通过微软提供的CSharpCodeProvider,CompilerParameters,CompilerResults等类,可以在运行时,动态执行自己写的代码文件.原理就是把你的代码文件动态编译成e ...

  3. C#复习题(概念) --C#学习笔记

    第一章 1.公共语言架构(CLI)由哪几部分组成? (1)通用类型系统:定义了一套类型系统的框架,规定了数据类型的声明.使用和管理方法. (2)公共语言规范:一组语言规则的集合 (3)通用中间语言:一 ...

  4. 2018-02-16 GetSameTypeQuestion

    '目前存在的BUG '图片补丁存在多个URL Private Declare Function URLDownloadToFile Lib "urlmon" Alias " ...

  5. canvas学习之小球动画

    项目地址:http://pan.baidu.com/s/1skZGPgL 最近学习使用canvas做动画效果,主要原理就是创建一个小球对象,然后小球对象有一个moveball方法,每次让小球沿着随机路 ...

  6. find_first_zero_bit在使用gcc 4.2.4 编译时,需要保护%eax

    1.3.100 find_first_zero_bit在使用gcc 4.2.4 编译时,需要保护%eax find_first_zero_bit 修订后: /* * Find-bit routines ...

  7. CF903G Yet Another Maxflow Problem

    考虑最大流=最小割 不妨把a到a的边称为a类边,b到b的称为b类边,a到b的称为c类边. 显然,答案一定是由最多1条a和最多一条b以及一些c组成的. 只有a是会变的,也就是说每个a对应了唯一的最优的b ...

  8. HTML 5 <span> 标签

    标签定义及使用说明 <span> 用于对文档中的行内元素进行组合. <span> 标签没有固定的格式表现.当对它应用样式时,它才会产生视觉上的变化.如果不对 <span& ...

  9. Mybatis 查询tinyint(1)的数据库字段时会自动转换成boolean类型

    解决方案:将字段的tinyint(1)变成tinyint(2)

  10. oracle 常用字符串函数

    select  initcap('guodongdong') from dual;                                  /返回字符串并将字符串的第一个字母变为大写;  s ...