总结一:
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支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
5.Redis在很多方面具备数据库的特征,或者说就是一个数据库系统,而Memcached只是简单的k/v缓存
总结三:
redis和memcached的不同在于
1.存储方式:
memecache把数据全部存在内存之中,断电后会挂掉,数据不能超过内存大小
redis有部分存在硬盘上,这样能保证数据的持久型。
2.数据支持类型
redis在数据支持上要比memcache多得多
3.使用底层模型不同:
新版本的redis直接自己构建了vm机制,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求。
4.运行环境不同:
redis目前官方只支持linux上运行,从而省去了对其他系统的支持,这样的话可以更好的把精力用于本系统环境
上的优化,虽然后来微软有一个小组为其写了补丁,但是没有放到主干上。
memcache只能当做缓存,cache。
redis的内容是可以落地的,就是说跟mongodb有些类似,然后redis也可以作为缓存,并且可以设置master-slave
继续阅读与本文标签相同的文章
5G视频彩铃:它可能不会变成广告,但你得掏钱
-
如何在微服务架构中实现安全性?
2026-05-18栏目: 教程
-
微服务需要拆分到什么程度?
2026-05-18栏目: 教程
-
微服务中如何使用API组合模式进行查询?
2026-05-18栏目: 教程
-
Spring Cloud Zuul 那些你不知道的功能点
2026-05-18栏目: 教程
-
Apollo服务端设计原理剖析
2026-05-18栏目: 教程
