前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >memcache和memcached的区别

memcache和memcached的区别

作者头像
Marser
发布2018-06-25 17:00:56
1.7K0
发布2018-06-25 17:00:56
举报
文章被收录于专栏:智能合约智能合约

前两天,大家在群里讨论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/

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:201601-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • What is Memcached?
  • memcache又是什么?
  • memcached又是什么鬼?
  • 使用建议
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档