欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

php實現(xiàn)并發(fā)的方法

這篇文章將為大家詳細講解有關(guān)php實現(xiàn)并發(fā)的方法,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

十載的北流網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。營銷型網(wǎng)站建設(shè)的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整北流建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)公司從事“北流網(wǎng)站設(shè)計”,“北流網(wǎng)站推廣”以來,每個客戶項目都認真落實執(zhí)行。

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

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

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

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

Innodb存儲引擎支持行級鎖,當(dāng)某行數(shù)據(jù)被鎖定時,其他進程不能對這行數(shù)據(jù)進行操作

先查詢并鎖定行:

select stock_num from table where id=1 for update
if(stock_num > 0){
//下訂單
update table set stock_num=stock-1 where id=1
}

方案三:使用隊列

將用戶的下單請求依次存入一個隊列中,后臺用一個單獨的進程處理隊列中的下單請求

方案四:使用redis

redis的操作都是原子性的,可以將商品的庫存存入redis中,下單之前對庫存進行decr操作,如果返回的值大于等于0等可以下單,否則不能下單,這種方式效率較高

if(redis->get('stock_num') > 0){
 stock_num = redis->decr('stock_num')
 if(stock_num >= 0){
 //下訂單
 }else{
 //庫存不足
 }
}else{
//庫存不足
}

其他并發(fā)問題:

在現(xiàn)實應(yīng)用中,很多情況下會把數(shù)據(jù)存入緩存,當(dāng)緩存失效時,去數(shù)據(jù)庫取數(shù)據(jù)并重新設(shè)置緩存,如果這時并發(fā)量很大,會有很多進程同時去數(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);
}

關(guān)于php實現(xiàn)并發(fā)的方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

本文名稱:php實現(xiàn)并發(fā)的方法
標題路徑:http://aaarwkj.com/article26/iijscg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、品牌網(wǎng)站設(shè)計營銷型網(wǎng)站建設(shè)、標簽優(yōu)化外貿(mào)網(wǎng)站建設(shè)、外貿(mào)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)
国产精品欧美一区久久| 老熟女乱色一区二区三区| 末满18周岁禁止观看| 国产日产亚洲综合一区| 不卡一区二区黄色av| 99热视频在线观看免费| 亚洲乱色一区二区三区丝袜| 国产乱av一区二区三区| 麻豆视频91免费观看| 日本高清免费观看一区| 欧美亚洲av一区二区三区| 中文字慕日韩精品欧美一区| 91嫩草国产在线观看| 欧美日韩精品人妻一区| 亚洲午夜经典一区二区日韩| 一区二区三区av夏目彩春| 日本姜女黄视频免费看| 亚洲中少妇久久中文字幕| 欧美亚洲午夜精品久久久| 日本二区三区在线视频| 久久久国产精品9999综合| 高清欧美大片免费观看| 亚洲婷婷久久一区二区| 九九热最新视频免费看| 99久久精品人妻一区| 久久久久久成人亚洲| 亚洲av区一区二区三| 国产精品日韩伦理一区二区| 日日躁夜夜躁狠狠躁黑人| 成熟人妻中文字幕在线看| 日韩国产乱码一区中文字幕| 日本韩国三级视频在线观看| 久久精品国产亚洲av麻豆尤物| 看夫妻性生活免费视频| 久久国产精品一区二区三区| 国产原创av剧情在线播放| 欧美日韩精品人妻一区| 天天爽天天看天天射天天操| 亚洲大片色一区在线观看| 先锋影音女同中文字幕| 97成人在线视频免费|