redis 与 memcache的区别

Memcache和redis的区别是什么?

版权相同

它们都是使用的 它们都是使用的bsd协议,使用它的项目可以用于商业用户,不必发布二次修改的代码,可以修改源代码。 协议,使用它的项目可以用于商业用户,不必发布二次修改的代码,可以修改源代码。

数据类型

redis数据类型丰富,支持 数据类型丰富,支持set liset等类型 等类型
memcache支持简单数据类型,需要客户端自己处理复杂对象 支持简单数据类型,需要客户端自己处理复杂对象

持久性

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

分布式存储

redis支持 支持master-slave复制模式 复制模式
memcache可以使用一致性 可以使用一致性hash做分布式 做分布式

value大小不同

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

数据一致性不同

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

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只能当做缓存


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值