利用flock()函數對文件進行加鎖(排它鎖),實現并發按序進行。
flock(file,lock,block)有三個參數。
file : 已經打開的文件
lock : 鎖的類型
LOCK_SH : 共享鎖定(讀鎖)
LOCK_EX : 獨占鎖定(排它鎖,寫鎖)
LOCK_UN : 解鎖
LOCK_NB : 如果希望在文件鎖定時阻塞進程,那么需要加上該參數
block : 設置為true的時候,鎖定文件時,會阻止其他進程
下面是一個簡單demo/** * 阻塞模式(后面的進程會一直等待前面的進程執行完畢) */ public function crateOrder() { $file = fopen(__DIR__."/lock.txt","w+"); //加鎖 if(flock($file,LOCK_EX)) { //TODO 執行業務代碼 flock($file,LOCK_UN);//解鎖 } //關閉文件 fclose($file); } /** * 非阻塞模式(只要當前文件有鎖存在,那么直接返回) */ public function crateOrder() { $file = fopen(__DIR__."/lock.txt","w+"); //加鎖 if(flock($file,LOCK_EX|LOCK_NB)) { //TODO 執行業務代碼 flock($file,LOCK_UN);//解鎖 } else { //TODO 執行業務代碼 返回系統繁忙等錯誤提示 } //關閉文件 fclose($file); }
小提示:在執行fclose()的時候文件也會自動解鎖,所以可以省略解鎖的代碼
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/29371.html
摘要:前面寫過利用文件鎖來處理高并發的問題的,現在我們說另外一個處理方式,利用的鎖來解決高并發的問題先看沒有利用事務的時候并發的后果創建庫存管理表創建訂單管理表測試代碼我們預置庫存是十個,然后執行測試查看結果 前面寫過利用文件鎖來處理高并發的問題的,現在我們說另外一個處理方式,利用Mysql的鎖來解決高并發的問題 先看沒有利用事務的時候并發的后果 創建庫存管理表 CREATE TABLE `...
摘要:以購買商品舉例從數據庫獲取庫存的數量。這里暫時就不測試了,下面會針對并發的處理給出測試結果。第二種方案,使用的文件鎖。特點當調用鎖一個文件時,如果沒有獲取鎖,直接返回,不會出現阻塞。的表鎖和的文件鎖在應對并發數量上也有差別,自己可以多測試。 以購買商品舉例: ① 從數據庫獲取庫存的數量。② 檢查一下庫存的數量是否充足。③ 庫存的數量減去買家購買的數量(以每個用戶購買一個為例)。④ 最后...
閱讀 2722·2021-11-11 17:21
閱讀 613·2021-09-23 11:22
閱讀 3578·2019-08-30 15:55
閱讀 1641·2019-08-29 17:15
閱讀 573·2019-08-29 16:38
閱讀 904·2019-08-26 11:54
閱讀 2504·2019-08-26 11:53
閱讀 2749·2019-08-26 10:31