前两天,大家在群里讨论memcache缓存时,有群友提到了在memcache中如何存储数组,并如何直接通过数组索引取值的问题?当时,大家的回答基本一致是memcache是key-value形式的内存缓存系统。对于缓存key,只能是string类型,而无法存储array类型的key。虽然大家的理解基本保持一致,但是本着求证的态度,我还是查阅了php官方文档。官方示例代码如下:
代码语言:javascript复制<?php
$m = new Memcached();
$m->addServer('localhost', 11211);
$items = array(
'key1' => 'value1',
'key2' => 'value2',
'key3' => 'value3'
);
$m->setMulti($items);
$result = $m->getMulti(array('key1', 'key3', 'badkey'), $cas);
var_dump($result, $cas);
?>
以上代码的输出如下:
代码语言:javascript复制array(2) {
["key1"]=>
string(6) "value1"
["key3"]=>
string(6) "value3"
}
array(2) {
["key1"]=>
float(2360)
["key3"]=>
float(2362)
}
Memcached::setMulti()类似于Memcached::set(),它是一次存储多个key/value元素,以便于对多个元素的操作。之前我理解为key可以是array数组,但实际上并不是。setMulti()方法相当于是多次调用set()方法存储数据。在这里谢谢@乌大湿的指点。群友的问题暂时无解,那代码中的memcached和我们平常认知的memcache有何不同?
What is Memcached?
我们首先来介绍一下memcached服务端。memcached官网的介绍如下:
*Free & open source, high-performance, distributed memory object caching system, generic in nature, but intended for use in speeding up dynamic web applications by alleviating database load.
Memcached is an in-memory key-value store for small chunks of arbitrary data (strings, objects) from results of database calls, API calls, or page rendering.*
简单的说,memcached是一款开源免费的,以key-value形式缓存数据的高性能分布式内存缓存系统。它是以守护进程(daemon)的形式常驻内存当中,即memcached是一个服务端。它通常用来缓存数据,减少数据库的负载以提升应用的性能。
memcache又是什么?
PHP官方包中对memcache的解释如下:
在“Summary”中已经说明memcache是php扩展,用于连接操作memcached服务端。最新版本是2013年04月07日的3.0.8。
我们注意到,在解决文章开篇提出的问题时,是用了“setMulti”和“getMulti”两个函数,但是memcache函数列表中,并没有这两个方法:
这两个方法却是在memcached函数列表中
memcached不是以守护进程形式长驻内存当中的服务端么?这里的memcached又是什么鬼?
memcached又是什么鬼?
在php官方包中对memcached的介绍如下:
“Summary”和“Description”中解释说,memcached是php扩展,通过libmemcached库提供的API来操作memcached服务端。最新版本是2014年04月01日更新的2.2.0。
介绍到这里,相信大家已经基本明白了。memcached是以守护进程形式,长驻内存当中的高性能分布式的key-value缓存系统,而我们常说的memcache是PHP连接memcached服务端的扩展,版本比较老,姑且称之为老扩展。同时也存在一个PHP连接memcached服务端的扩展,叫memcached,扩展名与服务端名相同。因为支持的函数与协议比老的memcache扩展多,版本也比较新,姑且称之为新扩展。
使用建议
在文档中的函数列表里,通过对比可以看到memcached新扩展的函数比memcache老扩展的函数丰富,同时也支持array类型的key存储。这里也有一份memcache老扩展与memcached新扩展的功能对比,大家可以了解一下。
经过新浪微博和UC总结的经验和教训,memcache老扩展在分布式读取数据和高并发下的稳定性上都有一些问题,而memcached新扩展的表现却稳定的多。所以在使用当中建议将memcache老扩展切换成memcached新扩展。
附上memcached安装教程链接:http://www.marser.cn/archives/75/
- 本站文章除注明转载外,均为本站原创
- 欢迎任何形式的转载,但请务必注明出处,尊重他人劳动
- 转载请注明:文章转载自:Marser [https://www.marser.cn]
- 本文标题:memcache和memcached的区别
- 本文固定链接: https://www.marser.cnarticle/110.html