在web开发中我们经常对我们的数据库耗时操作做缓存,但是可能出现一个陷阱,在缓存失效的一瞬间,大量的访问得到缓存失效的标示,都去后端查询数据库,导致同时大量的数据库耗时查询,出现数据库宕机等问题。此问题隐藏深,不容易查找。本项目主要用于解决php的进程间锁问题。 示例: <div class="codetitle"><a style="CURSOR: pointer" data="74840" class="copybut" id="copybut74840" onclick="doCopy('code74840')"> 代码如下:<div class="codebody" id="code74840"> <?php / 测试例子,同时打开两个页面,可以发现总是同时只能一个页面进入到锁区间的代码 @link http://code.google.com/p/phplock/ @author sunli @svnversion $Id: test.php 2 2009-11-24 07:14:27Z sunli1223 $ @version v1.0 beta1 @license Apache License Version 2.0 @copyright sunli1223@gmail.com / require 'class.phplock.php'; $lock = new PHPLock ( 'lock/','lockname' ); $lock->startLock (); $lock->startLock (); //process code echo "进入锁 rn"; ob_end_flush(); flush(); ob_flush(); sleep ( 5 ); //休眠20秒,模拟并发操作 echo "执行完成 rn"; $lock->unlock (); $lock->endLock (); echo "释放锁完成 rn"; / cache操作 @return $array / function getCache($key) { return $cache; } /* 设置缓存 @param string $key @param array $value / function setCache($key,$value) { } $cache=getCache($key); if (! $cache) { //缓存不存在,开始加锁 $lock = new PHPLock ( 'lock/',$key ); $lock->startLock (); $lock->startLock (); //尝试判断缓存是否有数据,可能已经有访问重建缓存了,就不需要再次查询数据库 $cache=getCache(); if(!$cache){ //数据库查询操作,代码省略了 $data=$dbdata; setCache($key,$data); } //释放锁 $lock->unlock (); $lock->endLock (); } ?>
相关文章推荐 PHP 进程锁定问题分析研究 (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|