Memcache和Redis选型

来源:互联网 发布:甘肃广电网络投诉电话 编辑:程序博客网 时间:2024/06/05 14:09
Memcache和Redis都能很好的满足解决数据库表数据量极大(千万条),要求让服务器更加快速地响应用户的需求的问题,它们性能都很高,总的来说,可以把Redis理解为是对Memcache的拓展,是更加重量级的实现,提供了更多更强大的功能。具体来说:
1.性能上:
性能上都很出色,具体到细节,由于Redis只使用单核,而Memcache可以使用多核,所以平均每一个核上Redis在存储小数据时比

Memcache性能更高。而在100k以上的数据中,Memcache性能要高于Redis,虽然Redis最近也在存储大数据的性能上进行优化,但是比起 Memcache,还是稍有逊色。


2.内存空间和数据量大小:

MemCache可以修改最大内存,采用LRU算法。Redis增加了VM的特性,突破了物理内存的限制。


3.操作便利上:

MemCache数据结构单一,仅用来缓存数据,而Redis支持更加丰富的数据类型,也可以在服务器端直接对数据进行丰富的操作,这样可以减少网络IO次数和数据体积。


4.可靠性上:

MemCache不支持数据持久化,断电或重启后数据消失,但其稳定性是有保证的。Redis支持数据持久化和数据恢复,允许单点故障,但是同时也会付出性能的代价。


5.应用场景:
Memcache:动态系统中减轻数据库负载,提升性能;做缓存,适合多读少写,大数据量的情况(如人人网大量查询用户信息、好友信息、文章信息等)。

Redis:适用于对读写效率要求都很高,数据处理业务复杂和对安全性要求较高的系统(如新浪微博的计数和微博发布部分系统,对数据安全性、读写要求都很高)。


其它:
1.Memcache单个key-value大小有限,一个value最大只支持1MB,而Redis最大支持512MB
2.Memcache只是个内存缓存,对可靠性无要求;而Redis更倾向于内存数据库,因此对对可靠性方面要求比较高
3.从本质上讲,Memcache只是一个单一key-value内存Cache;而Redis则是一个数据结构内存数据库,支持五种数据类型,因此Redis除单纯缓存作用外,还可以处理一些简单的逻辑运算,Redis不仅可以缓存,而且还可以作为数据库用

4.新版本(3.0)的Redis是指集群分布式,也就是说集群本身均衡客户端请求,各个节点可以交流,可拓展行、可维护性更强大。


节选自【http://blog.csdn.net/suifeng3051/article/details/23739295】

0 0
原创粉丝点击