phplock(php進程鎖) v1.0 beta1

來源:互聯網
上載者:User

在web開發中我們經常對我們的資料庫耗時操作做緩衝,但是可能出現一個陷阱,在緩衝失效的一瞬間,大量的訪問得到緩衝失效的標示,都去後端查詢資料庫,導致同時大量的資料庫耗時查詢,出現資料庫宕機等問題。此問題隱藏深,不容易尋找。本項目主要用於解決php的進程間鎖問題。
樣本: 複製代碼 代碼如下:<?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 "<span>進入鎖</span><br />\r\n";
ob_end_flush();
flush();
ob_flush();
sleep ( 5 ); //休眠20秒,類比並行作業
echo "執行完成<br />\r\n";
$lock->unlock ();
$lock->endLock ();
echo "釋放鎖完成<br />\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 進程鎖定問題分析研究

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.