久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

關(guān)于php 高并發(fā)解決的一點思路

涉及搶購、秒殺、抽獎、搶票等活動時,為了避免超賣,那么庫存數(shù)量是有限的,但是如果同時下單人數(shù)超過了庫存數(shù)量,就會導(dǎo)致商品超賣問題。那么我們怎么來解決這個問題呢,我的

我的思路如下(偽代碼):

sql1:查詢商品庫存

if(庫存數(shù)量 > 0)
{
//生成訂單...
sql2:同時庫存-1
}

當(dāng)沒有并發(fā)時,上面的流程看起來是再正常不過了,假設(shè)同時兩個人下單,而庫存只有1個了,在sql1階段兩個人查詢到的庫存都是>0的,于是最終都執(zhí)行了sql2,庫存最后變?yōu)?1,超售了,這不是我們想要的結(jié)果吧。

解決這個問題比較流行的思路我總結(jié)了下:
1.用額外的單進程處理一個隊列,下單請求放到隊列里,一個個處理,就不會有并發(fā)的問題了,但是要額外的開啟后臺進程以及延遲問題,這里暫不予考慮。這里我可使用消息隊列,我們常用到Memcacheq、Radis。 比如:有100張票可供用戶搶,那么就可以把這100張票放到緩存中,讀寫時不要加鎖。 當(dāng)并發(fā)量大的時候,可能有500人左右搶票成功,這樣對于500后面的請求可以直接轉(zhuǎn)到活動結(jié)束的靜態(tài)頁面。進去的500個人中有400個人是不可能獲得商品的。所以可以根據(jù)進入隊列的先后順序只能前100個人購買成功。后面400個人就直接轉(zhuǎn)到活動結(jié)束頁面。當(dāng)然進去500個人只是舉個例子,至于多少可以自己調(diào)整。而活動結(jié)束頁面一定要用靜態(tài)頁面,不要用數(shù)據(jù)庫。這樣就減輕了數(shù)據(jù)庫的壓力。
2.mysql樂觀鎖,意思是比如總庫存是2,搶購事件提交時,立馬將庫存+1,那么此時庫存是3,然后訂單生成后,在更新庫存前再查詢一次庫存(因為訂單生成理所當(dāng)然庫存-1,但是先不急,再查一次庫存返回結(jié)果是3),看看跟預(yù)期的庫存數(shù)量(這里預(yù)期的庫存是3)是否保持一致,不一致就回滾,提示用戶庫存不足。這里說道悲觀鎖,可能有朋友會問,那一定有樂觀鎖了吧??這里我就淺談下我所了解的悲觀與樂觀鎖了

悲觀鎖與樂觀鎖是兩種常見的資源并發(fā)鎖設(shè)計思路,也是并發(fā)編程中一個非常基礎(chǔ)的概念。本文將對這兩種常見的鎖機制在數(shù)據(jù)庫數(shù)據(jù)上的實現(xiàn)進行比較系統(tǒng)的介紹。

悲觀鎖(Pessimistic Lock)

悲觀鎖的特點是先獲取鎖,再進行業(yè)務(wù)操作,即“悲觀”的認為獲取鎖是非常有可能失敗的,因此要先確保獲取鎖成功再進行業(yè)務(wù)操作。通常所說的“一鎖二查三更新”即指的是使用悲觀鎖。通常來講在數(shù)據(jù)庫上的悲觀鎖需要數(shù)據(jù)庫本身提供支持,即通過常用的select … for update操作來實現(xiàn)悲觀鎖。當(dāng)數(shù)據(jù)庫執(zhí)行select for update時會獲取被select中的數(shù)據(jù)行的行鎖,因此其他并發(fā)執(zhí)行的select for update如果試圖選中同一行則會發(fā)生排斥(需要等待行鎖被釋放),因此達到鎖的效果。select for update獲取的行鎖會在當(dāng)前事務(wù)結(jié)束時自動釋放,因此必須在事務(wù)中使用。

這里需要注意的一點是不同的數(shù)據(jù)庫對select for update的實現(xiàn)和支持都是有所區(qū)別的,例如oracle支持select for update no wait,表示如果拿不到鎖立刻報錯,而不是等待,mysql就沒有no wait這個選項。另外mysql還有個問題是select for update語句執(zhí)行中所有掃描過的行都會被鎖上,這一點很容易造成問題。因此如果在mysql中用悲觀鎖務(wù)必要確定走了索引,而不是全表掃描。

樂觀鎖(Optimistic Lock)

樂觀鎖的特點先進行業(yè)務(wù)操作,不到萬不得已不去拿鎖。即“樂觀”的認為拿鎖多半是會成功的,因此在進行完業(yè)務(wù)操作需要實際更新數(shù)據(jù)的最后一步再去拿一下鎖就好。

樂觀鎖在數(shù)據(jù)庫上的實現(xiàn)完全是邏輯的,不需要數(shù)據(jù)庫提供特殊的支持。一般的做法是在需要鎖的數(shù)據(jù)上增加一個版本號,或者時間戳,然后按照如下方式實現(xiàn):

1. SELECT data AS old_data, version AS old_version FROM …;
2. 根據(jù)獲取的數(shù)據(jù)進行業(yè)務(wù)操作,得到new_data和new_version
3. UPDATE SET data = new_data, version = new_version WHERE version = old_version
if (updated row > 0) {
  // 樂觀鎖獲取成功,操作完成
} else {
  // 樂觀鎖獲取失敗,回滾并重試
}

樂觀鎖是否在事務(wù)中其實都是無所謂的,其底層機制是這樣:在數(shù)據(jù)庫內(nèi)部update同一行的時候是不允許并發(fā)的,即數(shù)據(jù)庫每次執(zhí)行一條update語句時會獲取被update行的寫鎖,直到這一行被成功更新后才釋放。因此在業(yè)務(wù)操作進行前獲取需要鎖的數(shù)據(jù)的當(dāng)前版本號,然后實際更新數(shù)據(jù)時再次對比版本號確認與之前獲取的相同,并更新版本號,即可確認這之間沒有發(fā)生并發(fā)的修改。如果更新失敗即可認為老版本的數(shù)據(jù)已經(jīng)被并發(fā)修改掉而不存在了,此時認為獲取鎖失敗,需要回滾整個業(yè)務(wù)操作并可根據(jù)需要重試整個過程。好吧,在此嘮叨總結(jié)下這兩個鎖:

總結(jié)

  • 【網(wǎng)站聲明】本站除付費源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了PHP定義字符串的四種方式,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
下面小編就為大家分享一篇php 替換文章中的圖片路徑,下載圖片到本地服務(wù)器的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇PHP給源代碼加密的幾種方法匯總(推薦),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇php打開本地exe程序,js打開本地exe應(yīng)用程序,并傳遞相關(guān)參數(shù)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP類的反射來實現(xiàn)依賴注入過程以及相關(guān)知識點分享,對此有興趣的朋友跟著小編學(xué)習(xí)下吧。
php遍歷一個文件夾內(nèi)的所有文件和文件夾,并刪除所有文件夾和子文件夾下的所有文件的代碼,通過遞歸方式實現(xiàn)達到清空一個目錄的效果。本文給大家分享實例代碼,需要的朋友參考
主站蜘蛛池模板: 国产精品视频一二三区 | 91久久| 亚洲成人av| 亚洲综合久久精品 | 日韩欧美三区 | 久久99国产精品久久99果冻传媒 | 精品1区2区3区4区 | 久久成人免费观看 | 女人av| 久国产视频 | 超碰激情 | 欧洲一级毛片 | 蜜臀久久 | 国产一区二区电影网 | 午夜一区二区三区视频 | 高清视频一区 | 男女免费在线观看视频 | 亚洲一区二区av | 亚洲一区二区三区视频 | 国产精品视频yy9299一区 | 午夜免费福利电影 | 中文字幕日韩一区 | 国产69久久精品成人看动漫 | 91精品一区二区三区久久久久久 | 99精品在线观看 | 视频一区在线观看 | 亚洲自拍偷拍欧美 | 亚洲精品一区二区三区在线 | 一区二区三区四区电影视频在线观看 | 中文字幕一区二区三区四区五区 | 久草资源网站 | 欧美在线观看网站 | 国产亚洲一区二区三区 | 成人免费视频观看视频 | 91美女视频 | 四虎影院在线免费观看 | 久久久久九九九女人毛片 | 五月激情综合 | 久艹av | 在线视频一区二区 | 亚洲欧美日韩在线不卡 |