`

关于mongodb ,redis,memcache之间见不乱理还乱的关系和作用

 
阅读更多

先说我自己用的情况:

最先用的memcache ,用于键值对关系的服务器端缓存,用于存储一些常用的不是很大,但需要快速反应的数据,然后,在另一个地方,要用到redis,然后就去研究了下redis. 一看,显示自己安装了php扩展,因为有服务器上的redis服务端,自己本地就没有安装,其实用法和memcache基本一样,可能就是几个参数有所不同。当然 它们缓存的效果也不一样,具体的哪里不一样,一下就是一些资料,和自己的总结

1、 Redis和Memcache都是将数据存放在内存中,都是内存数据库。不过memcache还可用于缓存其他东西,例如图片、视频等等。
2、 数据类型--Memcache在添加数据时就要指定数据的字节长度,例如:
set key3 0 0 8
lxsymcto
STORED
而redis不需要,如:redis 127.0.0.1:6379>set key2 "lxsymblog"
OK
redis 127.0.0.1:6379>get key2
"lxsymblog"
3、虚拟内存--Redis当物理内存用完时,可以将一些很久没用到的value 交换到磁盘
4、过期策略--memcache在set时就指定,例如set key1 0 0 8,即永不过期。Redis可以通过例如expire 设定,例如expire name 10
5、分布式--设定memcache集群,利用magent做一主多从;redis可以做一主多从。都可以一主一从
6、存储数据安全--memcache挂掉后,数据没了;redis可以定期保存到磁盘(持久化)
7、灾难恢复--memcache挂掉后,数据不可恢复; redis数据丢失后可以通过aof恢复

 

从以下几个维度,对redismemcachemongoDB 做了对比,欢迎拍砖

1、性能

都比较高,性能对我们来说应该都不是瓶颈

总体来讲,TPS方面redismemcache差不多,要大于mongodb

2、操作的便利性

memcache数据结构单一

redis丰富一些,数据操作方面,redis更好一些,较少的网络IO次数

mongodb支持丰富的数据表达,索引,最类似关系型数据库,支持的查询语言非常丰富

3、内存空间的大小和数据量的大小

redis2.0版本后增加了自己的VM特性,突破物理内存的限制;可以对key value设置过期时间(类似memcache

memcache可以修改最大可用内存,采用LRU算法

mongoDB适合大数据量的存储,依赖操作系统VM做内存管理,吃内存也比较厉害,服务不要和别的服务在一起

4、可用性(单点问题)

对于单点问题,

redis,依赖客户端来实现分布式读写;主从复制时,每次从节点重新连接主节点都要依赖整个快照,无增量复制,因性能和效率问题,

所以单点问题比较复杂;不支持自动sharding,需要依赖程序设定一致hash 机制。

一种替代方案是,不用redis本身的复制机制,采用自己做主动复制(多份存储),或者改成增量复制的方式(需要自己实现),一致性问题和性能的权衡

Memcache本身没有数据冗余机制,也没必要;对于故障预防,采用依赖成熟的hash或者环状的算法,解决单点故障引起的抖动问题。

mongoDB支持master-slave,replicaset(内部采用paxos选举算法,自动故障恢复),auto sharding机制,对客户端屏蔽了故障转移和切分机制。

5可靠性(持久化)

对于数据持久化和数据恢复,

redis支持(快照、AOF):依赖快照进行持久化,aof增强了可靠性的同时,对性能有所影响

memcache不支持,通常用在做缓存,提升性能;

MongoDB1.8版本开始采用binlog方式支持持久化的可靠性

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

Memcache 在并发场景下,用cas保证一致性

redis事务支持比较弱,只能保证事务中的每个操作连续执行

mongoDB不支持事务

7、数据分析

mongoDB内置了数据分析的功能(mapreduce),其他不支持

8、应用场景

redis:数据量较小的更性能操作和运算上

memcache:用于在动态系统中减少数据库负载,提升性能;做缓存,提高性能(适合读多写少,对于数据量比较大,可以采用sharding

MongoDB:主要解决海量数据的访问效率问题

 

 

 

最近一直在研究key-value的存储,简单记一下感受。。一些memcache和redis的安装和使用就不赘述啦。只简单说说两种方案的差别。一些感想和测试结果未必足够能说明问题,有什么不妥请大家指正。因为这两天在学习的过程发现一直在更正自己认识的缺陷,每天都会否定前一天的想法。。好了,费话少说。

  经过对50万个数据存储的研究发现:

  每秒单条指令执行量    

memcache 约3万次

  redis 约1万次

而且,memcache的一大优点是可以通过一个函数直接设置过期时间,而redis需要两个函数才可以既设置了键值对又设置过期时间,也就是redis在这点上效率变成了原来的一半,即5千次,这对于大部分需求来说,有点太慢了。

  memcache的测试代码如下:

<?php
$mem = new Memcache;
$mem->connect("127.0.0.1", 11211);
$time_start = microtime_float();
//保存数据
for($i = 0; $i < 100000; $i ++){
$mem->set("key$i",$i,0,3);
}
$time_end = microtime_float();
$run_time = $time_end - $time_start;
echo "用时 $run_time 秒\n";
function microtime_float(){
list($usec, $sec) = explode(" ", microtime());
return ((float)$usec + (float)$sec);
}
?>

 

redis的测试代码如下:redis1.php 此代码大概需要10秒左右

<?php
//连接
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$time_start = microtime_float();
//保存数据
for($i = 0; $i < 100000; $i ++){
$redis->sadd("key$i",$i);
}
$time_end = microtime_float();
$run_time = $time_end - $time_start;
echo "用时 $run_time 秒\n";
//关闭连接
$redis->close();
function microtime_float(){
list($usec, $sec) = explode(" ", microtime());
return ((float)$usec + (float)$sec);
}
?>

 

  如果需要在设置键值的同时设置过期时间,大概执行需要20秒左右,测试代码如下:redis2.php

<?php
//连接
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$time_start = microtime_float();
//保存数据
for($i = 0; $i < 100000; $i ++){
$redis->sadd("key$i",$i);
$redis->expire("key$i",3);
}
$time_end = microtime_float();
$run_time = $time_end - $time_start;
echo "用时 $run_time 秒\n";
//关闭连接
$redis->close();
function microtime_float(){
list($usec, $sec) = explode(" ", microtime());
return ((float)$usec + (float)$sec);
}
?>

 

  后来在网上发现redis有一个神奇的功能叫事务,通过multi原子性的将一段代码块依次执行,从而达到一个完整功能模块的执行。不幸的是,通过测试发现,采用multi方式执行代码时并没有减少请求次数,相反在执行multi指令和exec指令时都要发送请求,从而将运行时间变成了原来的四倍,即四条指令的运行时间。测试代码如下:redis3.php

<?php
//连接
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$time_start = microtime_float();
//保存数据
for($i = 0; $i < 100000; $i ++){
$redis->multi();
$redis->sadd("key$i",$i);
$redis->expire("key$i",3);
$redis->exec();
}
$time_end = microtime_float();
$run_time = $time_end - $time_start;
echo "用时 $run_time 秒\n";
//关闭连接
$redis->close();
function microtime_float(){
list($usec, $sec) = explode(" ", microtime());
return ((float)$usec + (float)$sec);
}

?>

 

 

  问题出现了瓶颈,有好多公司需要海量数据处理,每秒5000次远不能满足需求,然后由于redis主从服务器上比memcache有更大的优势,为了将来数据的着想,不得不使用redis,这时候出现了一种新的方式,即phpredis提供的pipline功能,该功能能够真正的将几条代码封装成一次请求,从而大大提高了运行速度,50万次的数据执行只有了58秒。测试代码如下:redis4.php

<?php

//连接

$redis = new Redis();

$redis->connect('127.0.0.1', 6379);

$time_start = microtime_float();

//保存数据

for($i = 0; $i < 100000; $i ++){

  $pipe=$redis->pipeline();

$pipe->sadd("key$i",$i);

$pipe->expire("key$i",3);

$replies=$pipe->execute();

}

$time_end = microtime_float();

$run_time = $time_end - $time_start;

echo "用时 $run_time 秒\n";

//关闭连接

$redis->close();

 

function microtime_float()

{

list($usec, $sec) = explode(" ", microtime());

return ((float)$usec + (float)$sec);

}

?>

   运用这个操作可以非常完美的将赋值操作和设置过期时间操作打包到一个请求去执行,大大提高了运行效率。

 

redis安装:http://mwt198668.blog.163.com/blog/static/48803692201132141755962/

memcache安装:http://blog.csdn.net/barrydiu/article/details/3936270

redis设置主从服务器:http://www.jzxue.com/fuwuqi/fuwuqijiqunyuanquan/201104/15-7117.html

memcache设置主从服务器:http://www.cnblogs.com/yuanermen/archive/2011/05/19/2051153.html

 来自:http://blog.csdn.net/a923544197/article/details/7594814

分享到:
评论

相关推荐

    Redis、Memcache、MongoDB区别

    1、里面包含Redis、MongoDB、Memcache相关的学习文档 2、对这三者有比较详细的应用场景告之,并描述出了三者之间区别 3、提供JAVA连接Redis常见问题的解决方案 4、对MongoDB的特性有专门文档作描述 5、对于新手而言...

    mongodb+redis资源

    MongoDB和Redis是两种非常流行的NoSQL数据库,它们在现代数据存储和处理中扮演着重要角色。MongoDB以其强大的文档型数据模型和高扩展性受到赞誉,而Redis则以其高速的键值存储和丰富的数据结构著称。让我们深入探讨...

    mongodb和redis数据库文档

    MongoDB和Redis是两种非常流行的NoSQL数据库,它们在现代数据存储和处理中扮演着重要角色。MongoDB是一个文档型数据库,而Redis则是一个键值对存储系统,两者各有其独特优势和适用场景。 MongoDB详解: MongoDB以其...

    左手MongoDB,右手Redis.zip

    本资料包“左手MongoDB,右手Redis.zip”包含了关于这两种数据库的深入理解和实践指导,主要通过PDF文档的形式呈现。 MongoDB是一种文档型数据库,以JSON格式的文档作为数据存储单元,具有强大的灵活性和可扩展性。...

    spring 使用MongoDB/redis

    spring 使用MongoDB/redis使用示例,简单易懂

    使用 Koa + MongoDB + Redis 搭建论坛系统【100012617】

    在本项目中,我们利用Koa作为Web应用框架,MongoDB作为主要的数据存储,Redis...通过这个项目,学生不仅可以掌握Koa、MongoDB和Redis的基本用法,还能了解到如何将它们整合到一个实际的应用中,从而提升Web开发技能。

    redis-mongodb-zookeeper-memcache安装

    ### Redis 安装与使用详解 #### 一、下载与安装 Redis 的安装流程较为简单。...需要注意的是,虽然 Redis 提供了丰富的功能,但在实际应用中还需要考虑性能优化、安全性等问题,确保系统的稳定性和可靠性。

    数据库安装包mysql mongodb redis

    在给定的压缩包文件中,包含了三种流行的关系型和非关系型数据库系统:MySQL、MongoDB和Redis的安装程序。下面将详细介绍这三个数据库系统及其特点。 1. **MySQL**: MySQL是一款开源、免费的关系型数据库管理系统...

    springboot整合mongodb+redis+mybatis+mysql

    本示例项目整合了多种数据库技术,包括 MongoDB、Redis 和 MyBatis,同时使用 MySQL 作为传统的关系型数据库。 MongoDB 是一个基于分布式文件存储的非关系型数据库,适用于处理大量数据的场景,尤其适合文档型数据...

    使用springboot,mongodb,redis搭建的高性能restfulAPI项目,开发快速

    在本项目中,我们主要利用Spring Boot、MongoDB和Redis三个关键组件来构建一个高性能的RESTful API服务。下面将详细解析这些技术及其在项目中的应用。 **Spring Boot** Spring Boot是Spring框架的一个子项目,旨在...

    java面试 分布式 集群 mongodb redis

    MongoDB和Redis是两种广泛使用的非关系型数据库,它们各有特点: **3.1 MongoDB** - **特性**:文档型数据库,适合存储结构化程度较低的数据。 - **应用场景**:日志数据、内容管理系统等。 **3.2 Redis** - **...

    Memcached Redis MongoDB对比

    Memcached、Redis和MongoDB都是流行的数据库解决方案,它们各自具有不同的特点和应用场景。以下是这三种技术之间的对比分析。 性能: 这三种数据库都具备高TPS(每秒事务处理数),意味着它们都能够处理大量的数据...

    NoSQL数据库-MongoDB和Redis

    ### NoSQL数据库-MongoDB和Redis #### 一、NoSQL简述 NoSQL数据库的出现是为了应对传统关系型数据库无法解决的一些问题,特别是在大规模数据处理方面。CAP理论(Consistency,Availability,Partition Tolerance)...

    php apache mysql memcache redis mongodb

    【标题】:“php apache mysql memcache redis mongodb”指的是在服务器端构建一套常见的Web开发环境,包括PHP编程语言、Apache HTTP服务器、MySQL数据库管理系统,以及两种内存缓存技术:Memcached和Redis,还有...

    php5.3.* memcache-mongodb-redis dll扩展

    标题中的“php5.3.* memcache-mongodb-redis dll扩展”表明了这是一个关于PHP5.3版本的扩展包,其中包含了对memcache、mongodb和redis数据库的支持。这些DLL文件是Windows平台上PHP运行时需要的动态链接库,用于增强...

    SpingMVC+MongoDB+Redis 初步架构设计

    在构建一个基于SpringMVC、MongoDB和Redis的初步架构设计时,我们需要深入了解这三大技术以及它们如何协同工作。SpringMVC是Spring框架的一部分,主要用于处理Web应用的模型-视图-控制器(MVC)结构。MongoDB是一个...

    基于mongodb数据库的集成redis缓存springboot实战

    通过这个实战项目,开发者不仅能掌握MongoDB和Redis的基本操作,还能了解到如何在SpringBoot框架下优雅地整合这两种技术,实现高效的缓存策略。这对于提升Web应用的性能和用户体验有着显著的效果。

    mysql+mongodb+redis.rar

    本压缩包“mysql+mongodb+redis.rar”包含了三个主流的数据库系统:MySQL、MongoDB和Redis,它们各自有着独特的特性和用途。以下是对这三个数据库系统的详细介绍: 1. **MySQL**: MySQL是一款开源、免费的关系型...

    京东爬虫 -- docker mongodb redis scrapy

    京东爬虫 -- docker mongodb redis scrapy等技术实现

Global site tag (gtag.js) - Google Analytics