解決高并發,庫存為負數的情況
阻塞模式如果其他進程已經加鎖文件,當前進程會一直等其他進程解鎖文件后繼續執行
flock($fp, LOCK_EX) // 文件鎖
如果其他進程已經加鎖文件,當前進程不會等其他進程解鎖文件,直接返> 回,也就是直接忽略加鎖的代碼到關閉文件那塊
flock($fp,LOCK_EX | LOCK_NB) // 文件鎖
flock($fp, LOCK_EX)
和 flock($fp,LOCK_EX | LOCK_NB)
換一下就行,其他都一樣
<?php$fp = fopen('lock.txt', 'r');if( flock($fp, LOCK_EX) ){ // flock($fp,LOCK_EX | LOCK_NB) $info = D()->query('SELECT surplus_total_num FROM tb_product WHERE id=1 LIMIT 1'); if( $info['surplus_total_num'] > 0 ){ D()->execute('UPDATE tb_product SET surplus_total_num = surplus_total_num - 1 WHERE id=1'); $isSurplusProduct = 1; }else{ $isSurplusProduct = 0; } flock($fp, LOCK_UN);}fclose($fp);if( !$isSurplusProduct ) exit('已經沒有產品了');并發測試
查看數據庫的庫存是否一致保持為0 ab參數:-c:并發數;-n:總請求數
ab -c 20 -n 1000 http://www.test.com/test.php
相關推薦:
php如何實現等比例html' target='_blank'>壓縮圖片的代碼
php命令行編寫shell命令的實例
以上就是PHP中鎖機制的應用的詳細內容,更多請關注 其它相關文章!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答