首頁 >後端開發 >php教程 >bigger than bigger phplockphp行程鎖 v10 beta1

bigger than bigger phplockphp行程鎖 v10 beta1

WBOY
WBOY原創
2016-07-29 08:41:171071瀏覽

在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 Lache Lache。
* @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_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 ($key );
    $lock-> >startLock ();
    //嘗試判斷快取是否有數據,可能已經有存取重建快取了,就不需要再查詢資料庫
    $cache=getCache();
     $cache=getCache();
   {
        //資料庫查詢作業,程式碼省略了
        $data=$dbdata;
    //釋放鎖
    $lock ->unlock ();
    $lock->endLock ();
}
?>



相關文章推薦

PHP 進程鎖定問題分析研究

以上就介紹了bigger than bigger phplockphp進程鎖 v10 beta1,包含了bigger than bigger方面的內容,希望對PHP教學有興趣的朋友有幫助。

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