phplock(php進(jìn)程鎖) v1.0 beta1
更新時(shí)間:2009年11月24日 21:41:02 作者:
PHP在多進(jìn)程模式下(并發(fā)的web訪問(wèn))由于沒(méi)有內(nèi)置的鎖支持,在處理一些資源的之后,很容易出現(xiàn)并發(fā)性問(wèn)題。
在web開(kāi)發(fā)中我們經(jīng)常對(duì)我們的數(shù)據(jù)庫(kù)耗時(shí)操作做緩存,但是可能出現(xiàn)一個(gè)陷阱,在緩存失效的一瞬間,大量的訪問(wèn)得到緩存失效的標(biāo)示,都去后端查詢數(shù)據(jù)庫(kù),導(dǎo)致同時(shí)大量的數(shù)據(jù)庫(kù)耗時(shí)查詢,出現(xiàn)數(shù)據(jù)庫(kù)宕機(jī)等問(wèn)題。此問(wèn)題隱藏深,不容易查找。本項(xiàng)目主要用于解決php的進(jìn)程間鎖問(wèn)題。
示例:
<?php
/**
* 測(cè)試?yán)?,同時(shí)打開(kāi)兩個(gè)頁(yè)面,可以發(fā)現(xiàn)總是同時(shí)只能一個(gè)頁(yè)面進(jìn)入到鎖區(qū)間的代碼
* @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 "<span>進(jìn)入鎖</span><br />\r\n";
ob_end_flush();
flush();
ob_flush();
sleep ( 5 ); //休眠20秒,模擬并發(fā)操作
echo "執(zhí)行完成<br />\r\n";
$lock->unlock ();
$lock->endLock ();
echo "釋放鎖完成<br />\r\n";
/**
* cache操作
*
* @return $array
*/
function getCache($key) {
return $cache;
}
/**
* 設(shè)置緩存
*
* @param string $key
* @param array $value
*/
function setCache($key,$value) {
}
$cache=getCache($key);
if (! $cache) {
//緩存不存在,開(kāi)始加鎖
$lock = new PHPLock ( 'lock/', $key );
$lock->startLock ();
$lock->startLock ();
//嘗試判斷緩存是否有數(shù)據(jù),可能已經(jīng)有訪問(wèn)重建緩存了,就不需要再次查詢數(shù)據(jù)庫(kù)
$cache=getCache();
if(!$cache){
//數(shù)據(jù)庫(kù)查詢操作,代碼省略了
$data=$dbdata;
setCache($key,$data);
}
//釋放鎖
$lock->unlock ();
$lock->endLock ();
}
?>
相關(guān)文章推薦
PHP 進(jìn)程鎖定問(wèn)題分析研究
示例:
復(fù)制代碼 代碼如下:
<?php
/**
* 測(cè)試?yán)?,同時(shí)打開(kāi)兩個(gè)頁(yè)面,可以發(fā)現(xiàn)總是同時(shí)只能一個(gè)頁(yè)面進(jìn)入到鎖區(qū)間的代碼
* @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 "<span>進(jìn)入鎖</span><br />\r\n";
ob_end_flush();
flush();
ob_flush();
sleep ( 5 ); //休眠20秒,模擬并發(fā)操作
echo "執(zhí)行完成<br />\r\n";
$lock->unlock ();
$lock->endLock ();
echo "釋放鎖完成<br />\r\n";
/**
* cache操作
*
* @return $array
*/
function getCache($key) {
return $cache;
}
/**
* 設(shè)置緩存
*
* @param string $key
* @param array $value
*/
function setCache($key,$value) {
}
$cache=getCache($key);
if (! $cache) {
//緩存不存在,開(kāi)始加鎖
$lock = new PHPLock ( 'lock/', $key );
$lock->startLock ();
$lock->startLock ();
//嘗試判斷緩存是否有數(shù)據(jù),可能已經(jīng)有訪問(wèn)重建緩存了,就不需要再次查詢數(shù)據(jù)庫(kù)
$cache=getCache();
if(!$cache){
//數(shù)據(jù)庫(kù)查詢操作,代碼省略了
$data=$dbdata;
setCache($key,$data);
}
//釋放鎖
$lock->unlock ();
$lock->endLock ();
}
?>
相關(guān)文章推薦
PHP 進(jìn)程鎖定問(wèn)題分析研究
您可能感興趣的文章:
相關(guān)文章
PHP實(shí)現(xiàn)簡(jiǎn)單漢字驗(yàn)證碼
大家知道簡(jiǎn)單數(shù)字或者字母驗(yàn)證碼很容易被破解,但是算式驗(yàn)證碼或者中文漢字驗(yàn)證碼不容易被破解,所以建議大家在使用驗(yàn)證碼的時(shí)候,盡量用算式驗(yàn)證碼或者中文漢字驗(yàn)證碼。2015-07-07PHP模擬asp中response類(lèi)實(shí)現(xiàn)方法
這篇文章主要介紹了PHP模擬asp中response類(lèi)的方法,可實(shí)現(xiàn)模擬ASP中response類(lèi)處理客戶端響應(yīng)的功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08PHP面向?qū)ο蟮倪M(jìn)階學(xué)習(xí)(抽像類(lèi)、接口、final、類(lèi)常量)
PHP面向?qū)ο蟮倪M(jìn)階學(xué)習(xí),主要包括抽像類(lèi)、接口、final、類(lèi)常量的一些資料2012-05-05PHP數(shù)據(jù)庫(kù)編程之MySQL優(yōu)化策略概述
這篇文章主要介紹了PHP數(shù)據(jù)庫(kù)編程之MySQL優(yōu)化策略,簡(jiǎn)單講述了mysql優(yōu)化的簡(jiǎn)單技巧以及索引優(yōu)化、查詢優(yōu)化、存儲(chǔ)優(yōu)化等相關(guān)操作技巧,需要的朋友可以參考下2017-08-08php 模擬GMAIL,HOTMAIL(MSN),YAHOO,163,126郵箱登錄的詳細(xì)介紹
本篇文章是對(duì)php模擬GMAIL,HOTMAIL(MSN),YAHOO,163,126郵箱登錄的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06