php中的memcache使用

一、Memcache简介

Memcache是danga.com的一个项目,最早是为LiveJournal服务的,目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力。它可以对应任意多个链接,使用非阻塞的网络IO。由于它的工作机制是在内存中开辟一块空间,然后建立一个HashTable,Memcached管理这些HashTable,所以速度非常快。

 

二、Memcache和Memcached的区别

为什么会有Memcache和Memcached两个名称?其实Memcache是这个项目的名称,而Memcached是他服务器端的主程序文件。一个是项目名称,一个是主程序文件名。

 

三、Memcache的服务器端和客户端安装

分为两个过程:Memcache服务器端的安装和Memcached客户端的安装

所谓服务器端的安装就在在服务器(一般都是linux系统)上安装Memcache实现数据的存储。

所谓客户端的安装就是指php去使用服务器端的Memcache提供的函数,需要php添加扩展。

 

四、PHP的Memcache客户端所有方法总结

memcache函数所有的方法列表如下:

Memcache::add - 添加一个值,如果已经存在,则返回false

Memcache::addServer - 添加一个可供使用的服务器地址

Memcache::close - 关闭一个Memcache对象

Memcache::connect - 创建一个Memcache对象

memcache_debug - 控制调试功能

Memcache::decrement - 对保存的某一个key中的值进行减法操作

Memcache::delete - 删除一个key值

Memcache::flush - 清除所有缓存的数据

Memcache::get - 获取一个key值

Memcache::getExtendedStats - 获取进程池中所有进程的运行系统统计

Memcache::getServerStatus - 获取运行服务器的参数

Memcache::getStats - 返回服务器的一些运行统计信息

Memcache::getVersion - 返回运行的Memcache的版本信息

Memcache::increment - 对保存的某个key中的值进行加法操作

Memcache::pconnect - 创建一个Memcache的持久连接对象

Memcache::replace - 对一个已有的key进行覆写操作

Memcache::set - 添加一个值,如果已经存在,则覆写

Memcache::setCompressThreshold - 对大于某一大小的数据进行压缩

Memcache::setServerParams - 在运行时修改服务器的参数

 

五、PHP的Memcache操作方法分解

 

Memcache::add用法:

 

bool Memcache::add(string $key,mixed $var[,int $flag[,int $expire]]);

说明:

如果$key不存在的时候,使用这个函数来存储$var的值。功能相同的函数memcache_add()。

 

参数:

$key:将要存储的键值。

$var:存储的值,字符型和整数型会按照原值保存,其他类型自动序列化以后保存。

$flag:是否用MEMCACHE_COMPRESSED来压缩存储的值,,true表示压缩,false表示不压缩。

$expire:存储值得过期时间,如果0表示不会过期,你可以用unix时间戳或者描述来表示从现在开始时间,但是你在使用秒数表示的时候,不要超过2592000秒(表示30天)。

 

返回值:如果成功返回true,失败则返回false。如果$key值已经存在,则会返回false,其他情况下Memcache::add()用法类似于Memcache::set()。

 

示例代码:

<?php

//面向对象

$memcache = new Memcache;

$memcache->connect('127.0.0.1',11211);

$memcache->add('var_key','test variable',false,30);

echo $memcache->get('var_key').'<br>';

$memcache->close();

 

//面向过程

$memcache = memcache_connect('127.0.0.1',11211);

memcache_add($memcache,'var_key','test variable',false,30);

echo memcache_get($memcache,'var_key');

memcache_close($memcache);

?>

 

Memcache::addServer用法:

 

bool Memcache::addServer ( string $host [, int $port [, bool $persistent [, int $weight [, int$timeout [, int $retry_interval [, bool $status [, callback $failure_callback ]]]]]]] )

 

说明:

添加一个可供使用的服务器地址到连接池中,连接用Memcache::addServer打开,脚本执行完后自动关闭,或者可以用Memcache::colse()手动关闭。相同的函数时memcache_add_server()。

 

当用这个方法的时候(相对于Memcache::connect()和Memcache::pconnect()方法),网络连接只有等需要的时候才会连接,因此不会因为增加很多的服务器到连接池而增加系统负担,因为很多服务器可能没有使用。

故障恢复会发生在这个方法执行的任何阶段,只要其他的服务器是正常的,这些连接请求的失败用户不会注意到。任何一种socket或者memcached服务器级的错误可以触发故障恢复。正常的客户端错误比如增加一个存在的键值不会引发故障恢复。

 


评论/留言