Redis,memcache,apc,apcu,yac介绍和比较

2,780 阅读4分钟

一 Redis和memcache
关于Redis和memcache的比较已经很多了,这里随意摘抄一篇文章:
http://www.open-open.com/lib/view/open1409643182369.html
大概有一下结论:
应该说Memcached和Redis都能很好的满足解决我们的问题,它们性能都很高,总的来说,可以把Redis理解为是对Memcached的拓展,是更加重量级的实现,提供了更多更强大的功能。具体来说:

1.性能上:
性能上都很出色,具体到细节,由于Redis只使用单核,而Memcached可以使用多核,所以平均每一个核上Redis在存储小数据时比
Memcached性能更高。而在100k以上的数据中,Memcached性能要高于Redis,虽然Redis最近也在存储大数据的性能上进行优化,但是比起 Memcached,还是稍有逊色。

2.内存空间和数据量大小:
MemCached可以修改最大内存,采用LRU算法。Redis增加了VM的特性,突破了物理内存的限制。

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

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

5.应用场景:
Memcached:动态系统中减轻数据库负载,提升性能;做缓存,适合多读少写,大数据量的情况(如人人网大量查询用户信息、好友信息、文章信息等)。
Redis:适用于对读写效率要求都很高,数据处理业务复杂和对安全性要求较高的系统(如新浪微博的计数和微博发布部分系统,对数据安全性、读写要求都很高)。

需要慎重考虑的部分

1.Memcached单个key-value大小有限,一个value最大只支持1MB,而Redis最大支持512MB
2.Memcached只是个内存缓存,对可靠性无要求;而Redis更倾向于内存数据库,因此对对可靠性方面要求比较高
3.从本质上讲,Memcached只是一个单一key-value内存Cache;而Redis则是一个数据结构内存数据库,支持五种数据类型,因此Redis除单纯缓存作用外,还可以处理一些简单的逻辑运算,Redis不仅可以缓存,而且还可以作为数据库用
4.新版本(3.0)的Redis是指集群分布式,也就是说集群本身均衡客户端请求,各个节点可以交流,可拓展行、可维护性更强大。

Redis是数据的持久化,也是一种nosql,它可以把需要的数据提前按照key-value存储好,这样用户取数据时,可以直接从key中取出一系列的数据,避免频繁的查表。而memcache可以把用户频繁取出来的key cache住,这样连redis都不用去取了。

二 apc和memcache

由于PHP的特性,每次执行完页面之后,所有运行中的对象都会被释放,所以APC和Memcached就可以用来在脚本、进程之间共享、缓存数据。

APC是PHP的一个扩展,会加载在PHP的进程中,除了可以将PHP代码解释成OPCode保存在内存中之外,还能在PHP的进程之间使用共享内存(系统内核的数据结构)来保存数据,而且完全透明

而Memcached是一个外部的服务,要通过tcp或udp的网络协议来共享/缓存数据

Memcached好处是可以在多台机器之间共享、缓存数据,或者是与其他非php应用共享数据,但由于使用网络协议进行交互,而且在交互过程中需要对php对象进行序列化、反序列化等,延迟较直接集成在PHP进程中的APC大很多

Facebook同时使用了APC和Memcache作了两层缓存

APC更多时候用作Opcode Cache, 而MemCache是用作CotentCache. APC用作Content Cache的时候, 它是单机Cache. 而MemCache可以实现多机共享. 所以类似一些Session共享问题, 就只能用类似MemCache的缓存.
另外因为设计问题, 如果你使用APC缓存易变的内容, 可能会造成缓存内容不同步.

三 apc和apcu
原来的APC:Alternative PHP Cache,包含了System Cache Entries 、Per-Directory Entries、User Cache Entries三大块。
而现在的APCu:APCu – APC User Cache,只包含一个User Cache Entries。
所以是个精简版

四 yac
关于yac直接看鸟哥的博客:
http://www.laruence.com/2013/03/18/2846.html
具体yac的描述如下:
yac is a shared memory user data cache for PHP. it can be used to replace APC or local memcached.

yac is lockless, that means, it is very fast, but there could be a chance you will get a wrong data(depends on how many key slots are allocated and how many keys are stored), so you’d better make sure that your product is not very sensitive to that.
为PHP提供共享用户数据,可以替代APC或者本地memcached,它的特性是无锁,非常快,但是可能有数据错误,所以推荐使用大键值内存。