php解決搶購(gòu)秒殺抽獎(jiǎng)等大流量并發(fā)入庫(kù)導(dǎo)致的庫(kù)存負(fù)數(shù)的問(wèn)題
我們知道數(shù)據(jù)庫(kù)處理sql是一條條處理的,假設(shè)購(gòu)買(mǎi)商品的流程是這樣的:
sql1:查詢商品庫(kù)存
if(庫(kù)存數(shù)量 > 0) { //生成訂單... sql2:庫(kù)存-1 }
當(dāng)沒(méi)有并發(fā)時(shí),上面的流程看起來(lái)是如此完美,假設(shè)同時(shí)兩個(gè)人下單,而庫(kù)存只有1個(gè)了,在sql1階段兩個(gè)人查詢到的庫(kù)存都是>0的,于是最終都執(zhí)行了sql2,庫(kù)存最后變?yōu)?1,超售了,要么補(bǔ)庫(kù)存,要么等用戶投訴吧。
解決這個(gè)問(wèn)題比較流行的思路:
1.用額外的單進(jìn)程處理一個(gè)隊(duì)列,下單請(qǐng)求放到隊(duì)列里,一個(gè)個(gè)處理,就不會(huì)有并發(fā)的問(wèn)題了,但是要額外的后臺(tái)進(jìn)程以及延遲問(wèn)題,不予考慮。
2.數(shù)據(jù)庫(kù)樂(lè)觀鎖,大致的意思是先查詢庫(kù)存,然后立馬將庫(kù)存+1,然后訂單生成后,在更新庫(kù)存前再查詢一次庫(kù)存,看看跟預(yù)期的庫(kù)存數(shù)量是否保持一致,不一致就回滾,提示用戶庫(kù)存不足。
3.根據(jù)update結(jié)果來(lái)判斷,我們可以在sql2的時(shí)候加一個(gè)判斷條件update ... where 庫(kù)存>0,如果返回false,則說(shuō)明庫(kù)存不足,并回滾事務(wù)。
4.借助文件排他鎖,在處理下單請(qǐng)求的時(shí)候,用flock鎖定一個(gè)文件,如果鎖定失敗說(shuō)明有其他訂單正在處理,此時(shí)要么等待要么直接提示用戶"服務(wù)器繁忙"
本文要說(shuō)的是第4種方案,大致代碼如下:
阻塞(等待)模式
<?php $fp = fopen("lock.txt", "w+"); if(flock($fp,LOCK_EX)) { //..處理訂單 flock($fp,LOCK_UN); } fclose($fp); ?>
非阻塞模式
<?php $fp = fopen("lock.txt", "w+"); if(flock($fp,LOCK_EX | LOCK_NB)) { //..處理訂單 flock($fp,LOCK_UN); } else { echo "系統(tǒng)繁忙,請(qǐng)稍后再試"; } fclose($fp); ?>
- PHP+JS實(shí)現(xiàn)的商品秒殺倒計(jì)時(shí)用法示例
- PHP 類商品秒殺計(jì)時(shí)實(shí)現(xiàn)代碼
- php結(jié)合redis實(shí)現(xiàn)高并發(fā)下的搶購(gòu)、秒殺功能的實(shí)例
- php+redis實(shí)現(xiàn)商城秒殺功能
- PHP多線程模擬實(shí)現(xiàn)秒殺搶單
- yii框架redis結(jié)合php實(shí)現(xiàn)秒殺效果(實(shí)例代碼)
- PHP精確到毫秒秒殺倒計(jì)時(shí)實(shí)例詳解
- php微信公眾號(hào)開(kāi)發(fā)之秒殺
- php和redis實(shí)現(xiàn)秒殺活動(dòng)的流程
- PHP結(jié)合Redis+MySQL實(shí)現(xiàn)冷熱數(shù)據(jù)交換應(yīng)用案例詳解
- PHP的Laravel框架結(jié)合MySQL與Redis數(shù)據(jù)庫(kù)的使用部署
- PHP商品秒殺問(wèn)題解決方案實(shí)例詳解【mysql與redis】
相關(guān)文章
PHP下的Oracle客戶端擴(kuò)展(OCI8)安裝教程
這篇文章主要介紹了PHP下的Oracle客戶端擴(kuò)展(OCI8)安裝教程,本文在Linux系統(tǒng)中實(shí)現(xiàn),OCI8是用來(lái)連接Oracle數(shù)據(jù)庫(kù)的PHP擴(kuò)展模塊,需要的朋友可以參考下2014-09-09PHP實(shí)現(xiàn)把MySQL數(shù)據(jù)庫(kù)導(dǎo)出為.sql文件實(shí)例(仿PHPMyadmin導(dǎo)出功能)
這篇文章主要介紹了PHP實(shí)現(xiàn)把MySQL數(shù)據(jù)庫(kù)導(dǎo)出為.sql文件實(shí)例(仿PHPMyadmin導(dǎo)出功能),需要的朋友可以參考下2014-05-05PHP 中 Orientation 屬性判斷上傳圖片是否需要旋轉(zhuǎn)
本文給大家介紹使用php技術(shù)實(shí)現(xiàn)根據(jù)上傳圖片orientation屬性判斷是否需要旋轉(zhuǎn),感興趣的朋友一起看看吧2015-10-10解決PHPstudy Apache無(wú)法啟動(dòng)的問(wèn)題【親測(cè)有效】
這篇文章主要介紹了PHPstudy Apache無(wú)法啟動(dòng)的問(wèn)題及解決方法【親測(cè)有效】,本文給大家總結(jié)了三種方法供大家參考,需要的朋友可以參考下2020-10-10Laravel框架控制器的middleware中間件用法分析
這篇文章主要介紹了Laravel框架控制器的middleware中間件用法,結(jié)合具體案例形式分析了Laravel框架控制器的middleware中間件相關(guān)使用步驟、操作技巧與注意事項(xiàng),需要的朋友可以參考下2019-09-09