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

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏技术博文

php 实现文件下载

1、php下载原理图 ? 2、文件下载源码: 1 <?php 2 $file_name="umiwi.apk";//需要下载的文件 3 $file_dir...

3654
来自专栏Java帮帮-微信公众号-技术文章全总结

Java基础-01总结概述,dos,功能键,path

1:计算机概述(了解) (1)计算机 (2)计算机硬件 (3)计算机软件 系统软件:window,linux,mac 应用软件:qq,yy,飞秋 (...

35913
来自专栏大内老A

WCF并发(Concurrency)的本质:同一个服务实例上下文(InstanceContext)同时处理多个服务调用请求

引言 服务(Service)的本质就是提供服务消费者期望的某种功能,服务的价值体现在两个方面:服务本身的质量和寄宿服务的平台应付消费者的数量,并发(Concur...

2046
来自专栏大内老A

[WCF 4.0新特性] 标准终结点与无(.SVC)文件服务激活

今天介绍WCF 4.0的另外两个新特性:标准终结点(Standard Endpoint)和无(.SVC)文件服务激活(File-Less Activation)...

23410
来自专栏漏斗社区

工具| 诸神之眼nmap定制化之并发处理

当我们使用nmap来进行大规模探测的时候,速度和准确度是摆在我们面前的两个问题,这时需要考虑到nmap的并发处理能力。 0x01 nmap本身的并发执行 相关...

3675
来自专栏Java技术栈

Maven Optional & Exclusions使用区别

Optional和Exclusions都是用来排除jar包依赖使用的,两者在使用上却是相反。 Optional定义后,该依赖只能在本项目中传递,不会传递到引用该...

3299
来自专栏Young Dreamer

babel入门基础

背景 babel的官网说babel是下一代的js语法编译器,现在自己也在很多项目中使用了babel,可是自己对babel的认识呢,只停留在从google和别人...

2625
来自专栏王亚昌的专栏

路由查找算法优化心得

    项目代码中有一个基础类库,用于解析client到server的路由配置文件,同时管理长连接。路由配置文件格式大致如下所示:

922
来自专栏Django Scrapy

Linux 目录结构及文件基本操作

win和类unix系统的文件目录的区别 一种不同是体现在目录与存储介质(磁盘,内存,DVD 等)的关系上,以往的 Windows 一直是以存储介质为主的,主要...

3066
来自专栏哲学驱动设计

BaaS API 设计规范

上个月写了一个团队中的 BaaS API 的设计规范,给大家分享下: 目录 1. 引言... 4 1.1. 概要... 4 1.2. 参考资料... 4 1...

23910

扫码关注云+社区