关于memcache这个现在应用广泛的组件,大大提高的网站的响应速度,也方便了程序开发缓存的应用。但是目前针对memcache,网上的资料 大同小异,尤其基于LAMP的网站居多,php/pcel又有两个memcache的client,所以导致很多混乱。这里我研究了两天,记录一下,也方 便有疑问的同学查看。

1   首先 memcache(服务端)的介绍就不多说了。一个基于内存的缓存系统,它是一个服务。并且*nux上大多数服务都以守护进程的形式存在,比如http服务有对应的httpd,ssh有对应的sshd 等等。所以针memcache的守护进程就是memcached 了,无可厚非。 安装好服务后,就是启动这个守护进程了。

/usr/local/bin/memcached –d   等等一系列选项 ,默认端口是11211  。关于memcache(服务端),请参考官网:http://memcached.org/  。

2   既然sever端有服务了,接下来就需要有client 能连接上,以提供服务啊。当然可以通过telnet
xxx.xxx.xxx.xx 11211
这种方式直接连上server端,这对于手工调试挺方便的。并且telnet上之后,有相关的stats/stats items /stats
cachedump x y  等命令。  但是对于各种语言的程序连接,则需要通过client来实现。接着php起先开发出来memcache服务端)的client(客户端)
,很不幸这个client叫做 memcache(客户端).   这个客户端以pcel形式发布:http://pecl.php.net/package/memcache。另外,php手册上对于memcache的使用:http://www.php.net/manual/en/memcache.examples-overview.php 
的例子也是基于这个client的。

3  后来09年的时候,Brian Aker开发出了一个基于c/c++ 的memcache的客户端,叫做libmemcache,官网:http://libmemcached.org/libMemcached.html   这个client维护更新很快,并且功能效率等都比php那个memcache(客户端)要好(你肯定会说当然了,因为一个是c/c++,一个是php。这个先暂时不争论,接着往后看)。这个client同时提供了更方便的命令行工具(省着telnet
11211):如memcat --servers=xxx  / memstat --servers=xxx 等。

4  有了libmemcache 这个牛X的client。php也不甘寂寞,何不拿来用呢?于是乎,php又弄出一个基于libmemcache的client,非常不幸这个client叫做memcached(客户端):也是以pcel形式发布:http://pecl.php.net/package/memcached 
.  这个client的特点基本跟 libmemcache差不多。

5 所以针对php开发来说,要在特定的语境里区分同名的意义。有时memcache ,有时 memcached ,有时client ,有时server 。不管怎么说,只要我们知道这其中关系跟原理,神马都是浮云。

class MCache
{ private static $server = array('127.0.0.1', 11211);
private static $client = 'memcached'; // memcache or memcached private static function get_memcache()
{
static $memcache;
if (!is_object($memcache))
{
$memcache = self::$client === 'memcached' ? new Memcached() : new Memcache ;
$memcache->addServer(self::$server[0],self::$server[1]);
}
return $memcache;
} public static function set($key, $value, $expire=600)
{
self::$client === 'memcached' ? self::get_memcache()->set($key, $value, $expire)
: self::get_memcache()->set($key, $value, MEMCACHE_COMPRESSED, $expire);
} public static function get($key)
{
return self::get_memcache()->get($key);
} } MCache::set('test_one', 'value_one', 60); # 60 Sec
print_r(MCache::get('test_one'));

转于:http://blog.csdn.net/aylazhang/article/details/6935569

扩展:给memcache中的key加命名空间:http://www.cnblogs.com/xianbei/archive/2011/01/02/1921258.html

memcache概念浅谈及名称混乱之区分的更多相关文章

  1. Arcgis Android 基本概念 - 浅谈

    MapView     MapView 是 Android 中 ViewGroup的子类,也是 ArcGIS Runtime SDK for Android 中的地图容器,与很多 ArcGIS API ...

  2. H5应用程序缓存浅谈及实际测试

    应用程序缓存能做什么? 可以在脱离网络的条件下离线访问. 减少读取服务器文件,减轻服务器的访问压力. 优化网站打开速度. 如何启用应用缓存? 第一步:给服务器添加新的MIME:扩展名:.appcach ...

  3. Android v2.0 基本概念 - 浅谈

    目录 Android框架 Linux Kernel 系统运行库 Libraries Android Runtime Application Framework Application Android框 ...

  4. 【转】数据仓库ODS、DW和DM概念区分

    今天看了一些专业的解释,还是对ODS.DW和DM认识不深刻,下班后花时间分别查了查它们的概念. ODS——操作性数据 DW——数据仓库 DM——数据集市 1.数据中心整体架构   数据中心整体架构 数 ...

  5. MemCache超详细解读

    MemCache是什么 MemCache是一个自由.源码开放.高性能.分布式的分布式内存对象缓存系统,用于动态Web应用以减轻数据库的负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高 ...

  6. 【腾讯Bugly干货分享】浅谈Android自定义锁屏页的发车姿势

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57875330c9da73584b025873 一.为什么需要自定义锁屏页 锁屏 ...

  7. 浅谈 Android 自定义锁屏页的发车姿势

    作者:blowUp,原文链接:http://mp.weixin.qq.com/s?__biz=MzA3NTYzODYzMg==&mid=2653577446&idx=2&sn= ...

  8. memcache详解

    MemCache是一个自由.源码开放.高性能.分布式的分布式内存对象缓存系统,用于动态Web应用以减轻数据库的负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高了网站访问的速度. Me ...

  9. SOA之(5)——REST的SOA(SOA with REST)概念

    REST的SOA(SOA with REST)概念 发展 1992年网站(Web Sites)是在Web浏览器和Web服务器直接通过HTTP传输HTML. 2000年WS-* (Web Service ...

随机推荐

  1. errno错误码及含义(中文)

    /usr/include/asm/errno.h #define EPERM 1 /* Operation not permitted */操作不允许 #define ENOENT 2 /* No s ...

  2. openresty记录响应body乱码问题

    问题背景 最近新上了一个功能,openresty通过syslog记录请求日志,然后由logstash推送至ES.测试上线时未发现这个问题,在日常查看日志的过程中,发现logstash推送有错误日志,错 ...

  3. linux下安装oracle需要的配置

    1.检查系统包安装情况 rpm -qa|grep binutils rpm -ivh sysstat-7.0.2.rpm rpm -ivh binutils-2.17.50.0.6-14.el5.*. ...

  4. Struts2实现登录流程

    本节将演示一个基本的登录流程,在登录界面中若输入正确的用户名和密码,跳转到登录成功界面:否则路转到登录失败界面. 1 建立一个名为LoginDemo的动态Web项目 2 添加struts2相关的jar ...

  5. 寻找i*j=m的个数

    问题描述 3*3的矩阵内容. 1 2 3 2 4 6 3 6 9 即a[i][j](1<=i<=n,1<=j<=n)=i*j. 问一个这样n*n的矩阵里面,里面m出现的次数. ...

  6. megalo -- 网易考拉小程序解决方案

    megalo 是基于 Vue 的小程序框架(没错,又是基于 Vue 的小程序框架),但是它不仅仅支持微信小程序,还支持支付宝小程序,同时还支持在开发时使用更多 Vue 的特性. 背景 对于用户而言,小 ...

  7. JSP中的TAG文件和TLD文件小结

    在jsp文件中,可以引用tag和tld文件. 1.对于tag文件 <%@ taglib prefix="ui" tagdir="/WEB-INF/tags" ...

  8. DevExpress TreeList使用教程之绑定多级树

    DevExpress TreeList使用教程之绑定多级树   概述:TreeList控件可以同时显示树结构和其他数据列,即在一个列上建立父子关系展开或收缩,同时还可以显示其他列的内容.在TreeLi ...

  9. 利用Referer请求头阻止"盗链"

    转自:http://wisdomsong2007.blog.163.com/blog/static/47783725200882523820664/ 前言 有一些站点自己没有提供下载空间,但是为了吸引 ...

  10. Netty利用ChannelGroup广播消息

    在Netty中提供了ChannelGroup接口,该接口继承Set接口,因此可以通过ChannelGroup可管理服务器端所有的连接的Channel,然后对所有的连接Channel广播消息. Serv ...