django解決訂單并發(fā)問題【推薦】
并發(fā)處理
在多個(gè)用戶同時(shí)發(fā)起對同一個(gè)商品的下單請求時(shí),先查詢商品庫存,再修改商品庫存,會(huì)出現(xiàn)資源競爭問題,導(dǎo)致庫存的最終結(jié)果出現(xiàn)異常。
解決辦法:
悲觀鎖
當(dāng)查詢某條記錄時(shí),即讓數(shù)據(jù)庫為該記錄加鎖,鎖住記錄后別人無法操作,使用類似如下語法
select stock from tb_sku where id=1 for update; SKU.objects.select_for_update().get(id=1)
悲觀鎖類似于我們在多線程資源競爭時(shí)添加的互斥鎖,容易出現(xiàn)死鎖現(xiàn)象,采用不多。
樂觀鎖
樂觀鎖并不是真實(shí)存在的鎖,而是在更新的時(shí)候判斷此時(shí)的庫存是否是之前查詢出的庫存,如果相同,表示沒人修改,可以更新庫存,否則表示別人搶過資源,不再執(zhí)行庫存更新。類似如下操作
update tb_sku set stock=2 where id=1 and stock=7; SKU.objects.filter(id=1, stock=7).update(stock=2)
任務(wù)隊(duì)列
將下單的邏輯放到任務(wù)隊(duì)列中(如celery),將并行轉(zhuǎn)為串行,所有人排隊(duì)下單。比如開啟只有一個(gè)進(jìn)程的Celery,一個(gè)訂單一個(gè)訂單的處理。
總結(jié)
以上所述是小編給大家介紹的django解決訂單并發(fā)問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
web.py在SAE中的Session問題解決方法(使用mysql存儲(chǔ))
這篇文章主要介紹了web.py在SAE中的Session問題解決方法(使用mysql存儲(chǔ)),本文直接給出實(shí)現(xiàn)代碼,代碼中包含詳細(xì)注釋,需要的朋友可以參考下2015-06-06
Python win32com 操作Exce的l簡單方法(必看)
下面小編就為大家?guī)硪黄狿ython win32com 操作Exce的l簡單方法(必看)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05
Python?實(shí)現(xiàn)一個(gè)全連接的神經(jīng)網(wǎng)絡(luò)
這篇文章主要介紹了Python?實(shí)現(xiàn)一個(gè)全連接的神經(jīng)網(wǎng)絡(luò),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-06-06
python實(shí)現(xiàn)數(shù)組平移K位問題
這篇文章主要介紹了python實(shí)現(xiàn)數(shù)組平移K位問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02

