数据库的缓存方法-memcached的使用

widuu 2012-12-5 PHP技术 4,313 1 喜欢 (0)

我们可以通过php手册来了解memcache的使用方法,memcached是一个高性能的分布式内存对象缓存系统,所以我们使用的时候需要实例化一下!
[php]
$mem=new Memcache();
$mem->addServer();//添加服务器 可以添加多个
$mem->getStats();//获取服务器统计信息
$mem->set('key', 'some really big variable', MEMCACHE_COMPRESSED, 50);//设置key的值为some really big variable过期时间是50秒
$mem->get('key');//获取key的值
$mem->delete('key');//删除key的值
[/php]

上边这些都是简单的应用,好多参数值也没有使用,当然手册上写的非常清楚她的使用方法,那我们写一个model类吧memcached的类来对数据库进行缓存处理

[php]
class MemcacheModel {
private $mc = null;
/**
* 构造方法,用于添加服务器并创建memcahced对象
*/
function __construct(){
$params = func_get_args();
$mc = new Memcache;
//如果有多个memcache服务器
if( count($params) > 1){
foreach ($params as $v){
call_user_func_array(array($mc, 'addServer'), $v);//回调函数使用$mc->addserver();循环添加服务器
}
//如果只有一个memcache服务器
} else {
call_user_func_array(array($mc, 'addServer'), $params[0]);

}
$this->mc=$mc;
}
/**
* 获取memcached对象
* @return object memcached对象
*/
function getMem(){
return $this->mc;
}
/**
* 检查mem是否连接成功
* @return bool 连接成功返回true,否则返回false
*/
function mem_connect_error(){
$stats=$this->mc->getStats(); //$mc->getstats();方法获取服务器的状态
if(empty($stats)){
return false;
}else{
return true;
}
}

private function addKey($tabName, $key){

$keys=$this->mc->get($tabName);
if(empty($keys)){
$keys=array();
}
//如果key不存在,就添加一个
if(!in_array($key, $keys)) {
$keys[]=$key; //将新的key添加到本表的keys中
$this->mc->set($tabName, $keys, MEMCACHE_COMPRESSED, 0);
return true; //不存在返回true
}else{
return false; //存在返回false
}
}
/**
* 向memcache中添加数据
* @param string $tabName 需要缓存数据表的表名
* @param string $sql 使用sql作为memcache的key
* @param mixed $data 需要缓存的数据
*/
function addCache($tabName, $sql, $data){

$key=md5($sql);
//如果不存在
if($this->addKey($tabName, $key)){
$this->mc->set($key, $data, MEMCACHE_COMPRESSED, 0);
}
}
/**
* 获取memcahce中保存的数据
* @param string $sql 使用SQL的key
* @return mixed 返回缓存中的数据
*/
function getCache($sql){
$key=md5($sql);
return $this->mc->get($key);
}

/**
* 删除和同一个表相关的所有缓存
* @param string $tabName 数据表的表名
*/
function delCache($tabName){
$keys=$this->mc->get($tabName);

//删除同一个表的所有缓存
if(!empty($keys)){
foreach($keys as $key){
$this->mc->delete($key, 0); //0 表示立刻删除
}
}
//删除表的所有sql的key
$this->mc->delete($tabName, 0);
}
/**
* 删除单独一个语句的缓存
* @param string $sql 执行的SQL语句
*/
function delone($sql){
$key=md5($sql);
$this->mc->delete($key, 0); //0 表示立刻删除
}
}
[/php]

这样我们就可以对数据库进行缓存了,当然使用方法是大家来说了算的,主要是您想怎么对您的数据进行缓存,还有主要要知道为什么要用memcached,当然这个是为了开发大型点的网站才使用的,一般的小型的企业站还是不需要使用的,当然在大型,想微博,我们会学习一下nosql像redis这些东西,我会带领大家一起学习,嗯,wdphp也要增加memcache类!呵呵大家多看下更新我的http://code.google.com/p/wdphp来获取最新的包!

欢迎转载,转载请注明来自微度网络-网络技术中心http://www.widuu.com

转载请注明来自微度网络,本文标题:《数据库的缓存方法-memcached的使用》

喜欢 0 发布评论
Top