首頁 >php教程 >PHP开发 >phplock(php進程鎖) v1.0 beta1

phplock(php進程鎖) v1.0 beta1

黄舟
黄舟原創
2016-12-14 15:07:401165瀏覽

在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 工作 2.0 .*/ 
require 'class.phplock.php'; 
$lock = new PHPLock ( 'lock/', 'lockname' );
$lock->startLock (); 
$lock->startLock (); 
//process code 
echo "進入鎖
rn"; 
ob_end_flush(); ); 
ob_flush(); 
sleep ( 5 ); //休眠20秒,模擬並發操作 
echo "執行完成
rn"; 
$lock->unlock (); 
$lock-rn"; 
$lock->unlock (); 
$lock->一個Lock ( ); 
echo "釋放鎖定完成
rn"; 
/** 
* cache操作 

* @return $array 
*/ 
function getCache($key) { 
return $cache; 

/** 
* 設定快取 

* @param string $key 
* @param array $value 
#3f/unction setCache($key,$value) {

$cache=getCache($key); 

if (! $cache) { 
//快取不存在,開始加鎖 
$lock = new PHPLock (洛/ ', $key ); 
$lock->startLock (); 
$lock->startLock (); 
//嘗試判斷快取是否有數據,可能已經有存取重建快取了,就不需要再查詢資料庫 
$ cache=getCache(); 
if(!$cache){ 
//資料庫查詢作業,程式碼省略了 
$data=$dbdata; 
setCache($key,$data); 

//釋放鎖定鎖定lock->unlock (); 
$lock->endLock (); 

?>

更多相關文章請關注PHP中文網(www.php.cn)!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn