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