2016
01-08

memcache和memcached的区别

前两天,大家在群里讨论memcache缓存时,有群友提到了在memcache中如何存储数组,并如何直接通过数组索引取值的问题?当时,大家的回答基本一致是memcache是key-value形式的内存缓存系统。对于缓存key,只能是string类型,而无法存储array类型的key。虽然大家的理解基本保持一致,但是本着求证的态度,我还是查阅了php官方文档。官方示例代码如下:

<?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);
?>

以上代码的输出如下:

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的解释如下:
memcache.png

在“Summary”中已经说明memcache是php扩展,用于连接操作memcached服务端。最新版本是2013年04月07日的3.0.8。

我们注意到,在解决文章开篇提出的问题时,是用了“setMulti”和“getMulti”两个函数,但是memcache函数列表中,并没有这两个方法:
mecache_method.png


这两个方法却是在memcached函数列表
memcached_method.png

memcached不是以守护进程形式长驻内存当中的服务端么?这里的memcached又是什么鬼?

memcached又是什么鬼?

php官方包中对memcached的介绍如下:
memcached.png

“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/

「真诚赞赏,手留余香」
您的支持将鼓励我继续创作 :)