Rumah >php教程 >PHP开发 >phplock(php进程锁) v1.0 beta1

phplock(php进程锁) v1.0 beta1

黄舟
黄舟asal
2016-12-14 15:07:401206semak imbas

在web开发中我们经常对我们的数据库耗时操作做缓存,但是可能出现一个陷阱,在缓存失效的一瞬间,大量的访问得到缓存失效的标示,都去后端查询数据库,导致同时大量的数据库耗时查询,出现数据库宕机等问题。此问题隐藏深,不容易查找。本项目主要用于解决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 "进入锁
\r\n"; 
ob_end_flush(); 
flush(); 
ob_flush(); 
sleep ( 5 ); //休眠20秒,模拟并发操作 
echo "执行完成
\r\n"; 
$lock->unlock (); 
$lock->endLock (); 
echo "释放锁完成
\r\n"; 
/** 
* 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中文网(www.php.cn)!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:SQL总结存储过程Artikel seterusnya:SQL Server基础:存储过程