php文件鎖
㈠ php簡單分布式鎖-PHP中的鎖
對於PHP的鎖,其實並沒有什麼太多的概念。拋棄一些第三方的依賴,看看有哪些可用的選擇。
目前可以想到的就這么多,在該項目中我們採用文件鎖,因為其它的兩個需要裝擴展。文件鎖的邏輯就非常簡單了
從網上摘抄了一個例子,使用的 eAccelerator 和 文件鎖兩種 傳送門
使用方法
㈡ php mysql的鎖機制 怎麼寫
MYSQL中的鎖:
語法 :
LOCK TABLE 表名1 READ|WRITE, 表名2 READ|WRITE .................. 【鎖表】
UNLOCK TABLES 【釋放表】
Read:讀鎖|共享鎖 : 所有的客戶端只能讀這個表不能寫這個表
Write:寫鎖|排它鎖: 所有當前鎖定客戶端可以操作這個表,其他客戶端只能阻塞
注意:在鎖表的過程中只能操作被鎖定的表,如果要操作其他表,必須把所有要操作的表都鎖定起來!
PHP中的文件鎖 (鎖的是文件,不是表)
文件鎖的文件與表有什麼關系?:一點關系也沒有,與令牌相似,誰拿到誰操作。所以表根本沒鎖。
測試時,有個文件就行,叫什麼名無所謂
㈢ PHP中文件鎖與進程鎖的使用區別
1.限制並發多進程或多台伺服器需要對同一文件進行訪問和修改;
2.對參與文件I/O的進程隊列化和人為阻塞;
3.在業務邏輯中對文件內容進行守護;
㈣ PHP怎麼防止一個頁面.被同時打開
使用 cookie、session 只能防止被同一個瀏覽器多次打開.
如果要做到任何時刻都只能被打開一次,需要用文件鎖.
㈤ php flock 獨占鎖啥意思
於php中文件鎖函數flock函數用法簡介,希望通過本文的介紹大家對於Linux方面能夠更加的了解
flock
(PHP 4, PHP 5)
flock — 輕便的咨詢文件鎖定
說明
bool flock ( int $handle , int $operation [, int &$wouldblock ] )
PHP 支持以咨詢方式(也就是說所有訪問程序必須使用同一方式鎖定, 否則它不會工作)鎖定全部文件的一種輕便方法。
Note:
在 Windows 下 flock() 將會強制執行。
flock() 操作的 handle 必須是一個已經打開的文件指針。operation 可以是以下值之一:
要取得共享鎖定(讀取的程序),將 operation 設為 LOCK_SH(PHP 4.0.1 以前的版本設置為 1)。
要取得獨占鎖定(寫入的程序),將 operation 設為 LOCK_EX(PHP 4.0.1 以前的版本中設置為 2)。
要釋放鎖定(無論共享或獨占),將 operation 設為 LOCK_UN(PHP 4.0.1 以前的版本中設置為 3)。
如果不希望 flock() 在鎖定時堵塞,則給 operation 加上 LOCK_NB(PHP 4.0.1 以前的版本中設置為 4)。
flock() 允許執行一個簡單的可以在任何平台中使用的讀取/寫入模型(包括大部分的 Unix 派生版和甚至是 Windows)。如果鎖定會堵塞的話(EWOULDBLOCK 錯誤碼情況下),可選的第三個參數會被設置為 TRUE。鎖定操作也可以被 fclose() 釋放(代碼執行完畢時也會自動調用)。
成功時返回 TRUE, 或者在失敗時返回 FALSE.
Example #1 flock() 例子
復制代碼 代碼如下:
<?php
$fp = fopen("/tmp/lock.txt", "w+");
if (flock($fp, LOCK_EX)) { // 進行排它型鎖定
fwrite($fp, "Write something here ");
flock($fp, LOCK_UN); // 釋放鎖定
} else {
echo "Couldn't lock the file !";
}
fclose($fp);
?>
Note:
由於 flock() 需要一個文件指針, 因此可能不得不用一個特殊的鎖定文件來保護打算通過寫模式打開的文件的訪問(在 fopen() 函數中加入 "w" 或 "w+")。
Warning
flock() 不能用於 NFS 以及其它一些網路文件系統。詳細資料查看自己操作系統的文檔。
在部分操作系統中 flock() 以進程級實現。當用一個多線程伺服器 API(比如 ISAPI)時,可能不可以依靠 flock() 來保護文件,因為運行於同一伺服器實例中其它並行線程的 PHP 腳本可以對該文件進行處理。
flock() 不支持舊的文件系統,如 FAT 以及它的派生系統。因此,此環境下總是返回 FALSE(尤其是對 Windows 98 用戶來說)。
php中文件鎖函數flock函數用法簡介:
語法:
bool flock ( int $handle , int $operation [, int &$wouldblock ] )
flock() 操作的 handle 必須是一個已經打開的文件指針。operation 可以是以下值之一:
1. 要取得共享鎖定(讀取程序),將 operation 設為 LOCK_SH(PHP 4.0.1 以前的版本設置為 1)
2. 要取得獨占鎖定(寫入程序),將 operation 設為 LOCK_EX(PHP 4.0.1 以前的版本中設置為 2)
3. 要釋放鎖定(無論共享或獨占),將 operation 設為 LOCK_UN(PHP 4.0.1 以前的版本中設置為 3)
4. 如果你不希望 flock() 在鎖定時堵塞,則給 operation 加上 LOCK_NB(PHP 4.0.1 以前的版本中設置為 4)
看下面代碼:
a.php
復制代碼 代碼如下:
<?php
$file = 「temp.txt」;
$fp = fopen($file , 'w『);
if(flock($fp , LOCK_EX)){
fwrite($fp , 「abc」);
sleep(10);
fwrite($fp , 「123」);
flock($fp , LOCK_UN);
}
fclose($fp);
?>
b.php
復制代碼 代碼如下:
<?php
$file = 「temp.txt」;
$fp = fopen($file , 'r');
echo fread($fp , 100);
fclose($fp);
?>
運行 a.php 後,馬上運行 b.php ,可以看到輸出:
abc
等 a.php 運行完後運行 b.php ,可以看到輸出:
abc
123
顯然,當 a.php 寫文件時數據太大,導致時間比較長時,這時 b.php 讀取數據不完整,在對b.php做修改
修改 b.php 為:
復制代碼 代碼如下:
<?php
$file = 「temp.txt」;
$fp = fopen($file , 'r『);
if(flock($fp , LOCK_EX)){
echo fread($fp , 100);
flock($fp , LOCK_UN);
} else{
echo 「Lock file failed…」;
}
fclose($fp);
?>
運行 a.php 後,馬上運行 b.php ,可以發現 b.php 會等到 a.php 運行完成後(即 10 秒後)才顯示:
abc
123
讀取數據完整,但時間過長,他要等待寫鎖釋放,再對b.php做修改。
修改 b.php 為:
復制代碼 代碼如下:
<?php
$file = 「temp.txt」;
$fp = fopen($file , 'r');
if(flock($fp , LOCK_SH | LOCK_NB)){
echo fread($fp , 100);
flock($fp , LOCK_UN);
} else{
echo 「Lock file failed…」;
}
fclose($fp);
?>
運行 a.php 後,馬上運行 b.php ,可以看到輸出:
Lock file failed…
證明可以返回鎖文件失敗狀態,而不是向上面一樣要等很久。
腳本之家小編結論:
建議作文件緩存時,選好相關的鎖,不然可能導致讀取數據不完整,或重復寫入數據。
file_get_contents 好像選擇不了鎖,不知道他默認用的什麼鎖,反正和不鎖得到的輸出一樣,是不完整的數據。
㈥ PHP下有沒有互斥鎖的實現方案
木有...至於鎖的方案一般由資源自己實現。比如對資料庫和緩存的訪問。PHP進程都是單線程模型,如果資源不可讀寫,則阻塞。不過PHP有文件鎖的機制,這貌似是PHP唯一支持的鎖...
㈦ PHP如何使用文件鎖解決高並發問題
<?php
//連接資料庫
$con=mysqli_connect("192.168.2.186","root","root","test");
//查詢商品數量是否大於0,大於0才能下單,並減少庫存
$fp = fopen("lock.txt", "r");
//加鎖
if(flock($fp,LOCK_EX))
{
$res=mysqli_fetch_assoc(mysqli_query($con,'SELECT total FROM shop WHERE id=1 LIMIT 1'));
if($res['total']>0){mysqli_query($con,'UPDATE shop SET total=total-1 WHERE id=1');}
//執行完成解鎖
flock($fp,LOCK_UN);
}
//關閉文件
fclose($fp);
unset($res);
mysqli_close($con);
?>
㈧ php里如果二個人同時操一個資料庫里表的欄位,怎麼避免
首先,這個問題只有在特殊情況下才算是問題,大多數情況下可以不作考慮。
然後,這是問題很難描述清楚,解決方案有多種,下面提供一種較方便易用的方式
場景(問題)描述如下:
0,用戶A、B同時打開一個頁面,頁面顯示,客戶表T_CUSTOMER欄位(C_NAME、C_AGE)
姓名:張三,年齡:25
1,A 將姓名「張三」改為「張三1」,然後保存
2,B 將年齡「25」改為「30」,然後保存
這樣A的操作就被覆蓋了,姓名又變回「張三」了,大家一般怎麼處處這種情況?
這里給出一個較易用的解決方案
給表添加一欄位:LAST_UPDATE,即最後更新時間
回放場景
0,用戶A、B同時打開一頁面,面頁顯示:
姓名:張三,年齡:25,LAST_UPDATE:2008-10-17 13:45:00
1,A 將姓名「張三」改為「張三1」,然後保存
重點在這里:更新數據時WHERE條件里多一條件:AND LAST_UPDATE = '2008-10-17 13:45:00'
更新成功,此時觸發器會將當前時間「2008-10-17 13:46:00」賦值給LAST_UPDATE
2,B 將將年齡「25」改為「30」,然後保存
B更新數據時WHERE條件里也有這個條件:AND LAST_UPDATE = '2008-10-17 13:45:00',但此時LAST_UPDATE的值已經在A修改記錄時變成2008-10-17 13:46:00
下面要做的就是給出提示了:喔喲,此信息在你發呆這段時間已被人改過啦,所以你需要返工。
觸發器代碼如下:
===================================================
CREATE OR REPLACE TRIGGER T_CUSTOMER
BEFORE UPDATE ON T_CUSTOMER
FOR EACH ROW
/*
記錄最後修改時間
*/
BEGIN
:NEW.LAST_UPDATE := SYSDATE;
END;
===================================================
如果觸發器不熟悉或者只是不喜歡用觸發器,完全可以修改記錄時同時給LAST_UPDATE欄位賦值,以此替代觸發器的作用。
㈨ php除了文件鎖
php除了文件鎖,還有共享鎖、排它鎖。共享鎖和排他鎖主要是為了解決並發導致的問題。在PHP中,共享鎖和排它鎖主要用在兩個地方,一個是資料庫,一個是文件。
㈩ php 如何鎖表
在進行數據表檢查或修補時,可以先將數據表鎖定,可確保數據表的安全:
mysql>LOCK TABLE tbl_name READ;
mysql>FLUSH TABLES;
將數據表鎖定後再進行檢查或修補的工作。完成後再解除鎖定:
mys(www.111cn.net)ql>UNLOCK TABLES;
//LOCK TABLE tbl_name READ表示要鎖定成只讀狀態,在這個狀態下用戶只能讀取數據表,不能寫入。
LOCK TABLE tbl_name WRITE則是更嚴格的鎖定,用戶不能讀取也不能寫入。