這篇文章將為大家詳細(xì)講解有關(guān)php實(shí)現(xiàn)并發(fā)的方法,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
十載的北流網(wǎng)站建設(shè)經(jīng)驗(yàn),針對設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。營銷型網(wǎng)站建設(shè)的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整北流建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)公司從事“北流網(wǎng)站設(shè)計(jì)”,“北流網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
方案一:使用文件鎖排它鎖
flock函數(shù)用于獲取文件的鎖,這個(gè)鎖同時(shí)只能被一個(gè)線程獲取到,其它沒有獲取到鎖的線程要么阻塞,要么獲取失敗
在獲取到鎖的時(shí)候,先查詢庫存,如果庫存大于0,則進(jìn)行下訂單操作,減庫存,然后釋放鎖
方案二:使用MySQL數(shù)據(jù)庫提供的悲觀鎖
Innodb存儲引擎支持行級鎖,當(dāng)某行數(shù)據(jù)被鎖定時(shí),其他進(jìn)程不能對這行數(shù)據(jù)進(jìn)行操作
先查詢并鎖定行:
select stock_num from table where id=1 for update if(stock_num > 0){ //下訂單 update table set stock_num=stock-1 where id=1 }
方案三:使用隊(duì)列
將用戶的下單請求依次存入一個(gè)隊(duì)列中,后臺用一個(gè)單獨(dú)的進(jìn)程處理隊(duì)列中的下單請求
方案四:使用redis
redis的操作都是原子性的,可以將商品的庫存存入redis中,下單之前對庫存進(jìn)行decr操作,如果返回的值大于等于0等可以下單,否則不能下單,這種方式效率較高
if(redis->get('stock_num') > 0){ stock_num = redis->decr('stock_num') if(stock_num >= 0){ //下訂單 }else{ //庫存不足 } }else{ //庫存不足 }
其他并發(fā)問題:
在現(xiàn)實(shí)應(yīng)用中,很多情況下會把數(shù)據(jù)存入緩存,當(dāng)緩存失效時(shí),去數(shù)據(jù)庫取數(shù)據(jù)并重新設(shè)置緩存,如果這時(shí)并發(fā)量很大,會有很多進(jìn)程同時(shí)去數(shù)據(jù)庫取數(shù)據(jù),導(dǎo)致很多請求
穿透到數(shù)據(jù)庫,而使數(shù)據(jù)庫奔潰,這里可用文件鎖來解決
$data = $cache->get('key'); if(!$data){ $fp = fopen('lockfile'); if(flock($fp, LOCK_EX)){ $data = $cache->get('key');//拿到鎖后再次檢查緩存,這時(shí)可能已經(jīng)有了 if(!$data){ $data = mysql->query(); $cache->set('key', $data); } flock($fp, LOCK_UN); } fclose($fp); }
關(guān)于php實(shí)現(xiàn)并發(fā)的方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。