zoukankan      html  css  js  c++  java
  • redis 和 memache 缓存的区别

    总结一:

     

    1.数据类型

     

    Redis数据类型丰富,支持set list等类型

    memcache支持简单数据类型,需要客户端自己处理复杂对象

     

    2.持久性

     

    redis支持数据落地持久化存储

    memcache不支持数据持久存储

     

    3.分布式存储

     

    redis支持master-slave复制模式

    memcache可以使用一致性hash做分布式

     

    value大小不同

     

    memcache是一个内存缓存,key的长度小于250字符,单个item存储要小于1M,不适合虚拟机使用

     

    4.数据一致性不同

     

    redis使用的是单线程模型,保证了数据按顺序提交。

    memcache需要使用cas保证数据一致性。CAS(Check and Set)是一个确保并发一致性的机制,属于“乐观锁”范畴;原理很简单:拿版本号,操作,对比版本号,如果一致就操作,不一致就放弃任何操作

     

    5.cpu利用

     

    redis单线程模型只能使用一个cpu,可以开启多个redis进程

     

    总结二:

     

    1.Redis中,并不是所有的数据都一直存储在内存中的,这是和Memcached相比一个最大的区别。

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

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

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

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

     

    总结三:

     

    redis和memecache的不同在于:

     

    1、存储方式:

    memecache 把数据全部存在内存之中,断电后会挂掉,数据不能超过内存大小

    redis有部份存在硬盘上,这样能保证数据的持久性。

    2、数据支持类型:

    redis在数据支持上要比memecache多的多。

    3、使用底层模型不同:

    新版本的redis直接自己构建了VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求。

    4、运行环境不同:

    redis目前官方只支持Linux 上去行,从而省去了对于其它系统的支持,这样的话可以更好的把精力用于本系统 环境上的优化,虽然后来微软有一个小组为其写了补丁。但是没有放到主干上

     

    memcache只能当做缓存,cache

    redis的内容是可以落地的,就是说跟MongoDB有些类似,然后redis也可以作为缓存,并且可以设置master-slave

  • 相关阅读:
    .NET 正则表达式使用高级技巧之替换类介绍
    道法术器势
    JS函数匿名替换
    批量更改数据库表架构(生成sql后直接执行!)
    转: 从现实生活中理解什么是广播机制
    public View getView(int position, View convertView, final ViewGroup parent)三个参数的意思
    Android Intent个人介绍
    WPF中Timer与DispatcherTimer类的区别
    C# 使用ManualResetEvent 进行线程同步
    C# 使用AutoResetEvent进行线程同步
  • 原文地址:https://www.cnblogs.com/bluealine/p/11040426.html
Copyright © 2011-2022 走看看