在web开发中我们经常对我们的数据库耗时操作做缓存,但是可能出现一个陷阱,在缓存失效的一瞬间,大量的访问得到缓存失效的标示,都去后端查询数据库,导致同时大量的数据库耗时查询,出现数据库宕机等问题。此问题隐藏深,不容易查找。本项目主要用于解决php的进程间锁问题。
示例:
复制代码 代码如下:
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";
function getCache($key) {
return $cache;
}
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 进程锁定问题分析研究



