非关系型数据库之间的区别(mongodb,memcache,redis)

1.性能方面

从总体上来看,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。
mongodb适合大量数据的存储,依赖操作系统VM做内存管理,吃内存比较厉害。

4.可用性(单点问题)

redis依赖客户端来实现分布式读写;主从复制的时候,每次从节点重新连接主节点都要依赖整个快照(把系统某个状态下的各种数据记录在一个文件里),无增量进行复制,因效率和性能的问题,所以可用性问题比较复杂;不支持自动sharding,需要依赖程序设定一致hash机制,
一种替换的方案就是不用redis本身的复制机制,采用自己做主动复制(多份存储),或者改成增量复制的方式(需要自己实现),一致性问题和性能的权衡
memcache本身没有冗余机制,也没有必要;对于故障预防,采用依赖成熟的hash或者环状的算法,解决单点故障引起的抖动问题
mongodb支持master-slave(主从复制),对客户端屏蔽了故障转移和切分机制

5.可靠性(持久化)

对于数据持久化和数据恢复
redis支持(快照,AOF):依赖快照进行持久化,AOF增强可靠性的同时,对性能有所影响
memcache不支持,通常用作缓存,提升性能
mongodb从1.8版本开始使用binlog(二进制文件,用于记录用户对数据库更新的SQL语句信息,例如更改数据库表和更改内容的SQL语句都会记录到binlog里,但是对库表等内容的查询不会记录)的方式支持持久化的可靠性

6.数据一致性(事务支持)

memcache在并发场景下,用cas(中央认证服务,一种独立开放的指令协议)保证一致性
redis事务支持比较弱,只能保证事务中的每个操作连续执行
mongodb支持事务

7.数据分析

mongodb内置了数据分析的功能,其他不支持

8.应用场景

redis:数据量比较小的更性能操作和运算上
memcache:用于动态系统中减少数据库负载,提升性能;做缓存,提升性能(适合读多写少,对于数据量比较大,可以采用sharding(分片))
mongodb:主要解决海量数据的效率访问效率问题

性能
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 恢复。

你可能感兴趣的:(redis笔记)