redis、memcache、mongoDB 作了对比

from: http://yang.u85.us/memcache_redis_mongodb.pdfphp

 

从如下几个维度,对redis、memcache、mongoDB 作了对比。
一、性能
都比较高,性能对咱们来讲应该都不是瓶颈。
整体来说,TPS 方面redis 和memcache 差很少,要大于mongodb。
二、操做的便利性
memcache 数据结构单一。(key-value)
redis 丰富一些,数据操做方面,redis 更好一些,较少的网络IO 次数,同时还提供list,set,
hash 等数据结构的存储。
mongodb 支持丰富的数据表达,索引,最相似关系型数据库,支持的查询语言很是丰富。
三、内存空间的大小和数据量的大小
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 作内存管理,吃内存也比较厉害,服务
不要和别的服务在一块儿。redis

四、可用性(单点问题)
对于单点问题,
redis,依赖客户端来实现分布式读写;主从复制时,每次从节点从新链接主节点都要依赖整
个快照,无增量复制,因性能和效率问题,
因此单点问题比较复杂;不支持自动sharding,须要依赖程序设定一致hash 机制。
一种替代方案是,不用redis 自己的复制机制,采用本身作主动复制(多份存储),或者改为
增量复制的方式(须要本身实现),一致性问题和性能的权衡
Memcache 自己没有数据冗余机制,也不必;对于故障预防,采用依赖成熟的hash 或者环
状的算法,解决单点故障引发的抖动问题。
mongoDB支持master-slave,replicase(t 内部采用paxos选举算法,自动故障恢复),auto sharding
机制,对客户端屏蔽了故障转移和切分机制。
五、可靠性(持久化)
对于数据持久化和数据恢复,
redis 支持(快照、AOF):依赖快照进行持久化,aof 加强了可靠性的同时,对性能有所影

memcache 不支持,一般用在作缓存,提高性能;
MongoDB 从1.8 版本开始采用binlog 方式支持持久化的可靠性
六、数据一致性(事务支持)
Memcache 在并发场景下,用cas 保证一致性算法

redis 事务支持比较弱,只能保证事务中的每一个操做连续执行
mongoDB 不支持事务
七、数据分析
mongoDB 内置了数据分析的功能(mapreduce),其余不支持
八、应用场景
redis:数据量较小的更性能操做和运算上
memcache:用于在动态系统中减小数据库负载,提高性能;作缓存,提升性能(适合读多写
少,对于数据量比较大,能够采用sharding)
MongoDB:主要解决海量数据的访问效率问题。mongodb

image

一、类型——memcache 和redis 都是将数据存放在内存,因此是内存数据库。固然,memcache
也可用于缓存其余东西,例如图片等等。
二、数据类型——Memcache 在添加数据时就要指定数据的字节长度,而redis 不须要。
三、虚拟内存——当物理内存用完时,能够将一些好久没用到的value 交换到磁盘。
四、过时策略——memcache 在set 时就指定,例如set key1 0 0 8,即永不过时。Redis 能够通
过例如expire 设定,例如expire name 10。
五、分布式——设定memcache 集群,利用magent 作一主多从;redis 能够作一主多从。均可
以一主一从。
六、存储数据安全——memcache 断电就断了,数据没了;redis 能够按期save 到磁盘。
七、灾难恢复——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 最大运行并发数shell

-P memcache 的pid
//0 压缩(是否MEMCACHE_COMPRESSED) 30 秒失效时间
//delete 5 是timeout
<?php
$memcache = new Memcache;
$memcache -> connect('127.0.0.1', 11211);
$memcache -> set('name','yang',0,30);
if(!$memcache->add('name','susan',0, 30)) {
//echo 'susan is exist';
}
$memcache -> replace('name', 'lion', 0, 300);
echo $memcache -> get('name');
//$memcache -> delete('name', 5);
printf "stats\r\n" | nc 127.0.0.1 11211
telnet localhost 11211 stats quit 退出
Redis 的配置文件端口6379
/etc/redis.conf
启动Redis
redis-server /etc/redis.conf
插入一个值
redis-cli set test "phper.yang"
获取键值
redis-cli get test
关闭Redis
redis-cli shutdown 关闭全部
redis-cli -p 6379 shutdown
<?php
$redis=new Redis();
$redis->connect('127.0.0.1',6379);
$redis->set('test', 'Hello World');
echo $redis->get('test');
Mongodb
apt-get install mongo
mongo 能够进入shell 命令行
pecl install mongo
Mongodb 相似phpmyadmin 操做平台RockMongo数据库

相关文章
相关标签/搜索