主頁 > 知識庫 > PHP開發(fā)中解決并發(fā)問題的幾種實(shí)現(xiàn)方法分析

PHP開發(fā)中解決并發(fā)問題的幾種實(shí)現(xiàn)方法分析

熱門標(biāo)簽:商丘外呼系統(tǒng)好處 周口網(wǎng)絡(luò)回?fù)芡夂粝到y(tǒng) 百度地圖標(biāo)注類型是酒店 全國各省地圖標(biāo)注點(diǎn) 網(wǎng)絡(luò)電話400申請 福建高頻外呼防封系統(tǒng)哪家好 外呼系統(tǒng)人工客服 隨州銷售電銷機(jī)器人公司 400電話申請辦理

本文實(shí)例講述了PHP開發(fā)中解決并發(fā)問題的幾種實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:

對于商品搶購等并發(fā)場景下,可能會出現(xiàn)超賣的現(xiàn)象,這時就需要解決并發(fā)所帶來的這些問題了

在PHP語言中并沒有原生的提供并發(fā)的解決方案,因此就需要借助其他方式來實(shí)現(xiàn)并發(fā)控制。

方案一:使用文件鎖排它鎖

flock函數(shù)用于獲取文件的鎖,這個鎖同時只能被一個線程獲取到,其它沒有獲取到鎖的線程要么阻塞,要么獲取失敗

在獲取到鎖的時候,先查詢庫存,如果庫存大于0,則進(jìn)行下訂單操作,減庫存,然后釋放鎖

方案二:使用Mysql數(shù)據(jù)庫提供的悲觀鎖

Innodb存儲引擎支持行級鎖,當(dāng)某行數(shù)據(jù)被鎖定時,其他進(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ì)列

將用戶的下單請求依次存入一個隊(duì)列中,后臺用一個單獨(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ù)據(jù)庫取數(shù)據(jù)并重新設(shè)置緩存,如果這時并發(fā)量很大,會有很多進(jìn)程同時去數(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');//拿到鎖后再次檢查緩存,這時可能已經(jīng)有了
    if(!$data){
      $data = mysql->query();
      $cache->set('key', $data);
    }
    flock($fp, LOCK_UN);
  }
  fclose($fp);
}

說白了,要解決并發(fā)問題就必須要加鎖,各種方案的本質(zhì)都是加鎖

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php+redis數(shù)據(jù)庫程序設(shè)計(jì)技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP基本語法入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • PHP并發(fā)場景的三種解決方案代碼實(shí)例
  • php并發(fā)加鎖問題分析與設(shè)計(jì)代碼實(shí)例講解
  • PHP解決高并發(fā)的優(yōu)化方案實(shí)例
  • php多進(jìn)程模擬并發(fā)事務(wù)產(chǎn)生的問題小結(jié)
  • PHP利用Mysql鎖解決高并發(fā)的方法
  • php curl批處理實(shí)現(xiàn)可控并發(fā)異步操作示例
  • php處理搶購類功能的高并發(fā)請求
  • PHP+Redis 消息隊(duì)列 實(shí)現(xiàn)高并發(fā)下注冊人數(shù)統(tǒng)計(jì)的實(shí)例
  • PHP使用Redis實(shí)現(xiàn)防止大并發(fā)下二次寫入的方法
  • php結(jié)合redis高并發(fā)下發(fā)帖、發(fā)微博的實(shí)現(xiàn)方法
  • 詳解php處理大并發(fā)大流量大存儲

標(biāo)簽:定西 十堰 海南 佛山 六安 迪慶 南寧 樂山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP開發(fā)中解決并發(fā)問題的幾種實(shí)現(xiàn)方法分析》,本文關(guān)鍵詞  PHP,開發(fā),中,解決,并,發(fā)問,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP開發(fā)中解決并發(fā)問題的幾種實(shí)現(xiàn)方法分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP開發(fā)中解決并發(fā)問題的幾種實(shí)現(xiàn)方法分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章