您好,登錄后才能下訂單哦!
并發處理
在多個用戶同時發起對同一個商品的下單請求時,先查詢商品庫存,再修改商品庫存,會出現資源競爭問題,導致庫存的最終結果出現異常。
解決辦法:
悲觀鎖
當查詢某條記錄時,即讓數據庫為該記錄加鎖,鎖住記錄后別人無法操作,使用類似如下語法
select stock from tb_sku where id=1 for update; SKU.objects.select_for_update().get(id=1)
悲觀鎖類似于我們在多線程資源競爭時添加的互斥鎖,容易出現死鎖現象,采用不多。
樂觀鎖
樂觀鎖并不是真實存在的鎖,而是在更新的時候判斷此時的庫存是否是之前查詢出的庫存,如果相同,表示沒人修改,可以更新庫存,否則表示別人搶過資源,不再執行庫存更新。類似如下操作
update tb_sku set stock=2 where id=1 and stock=7; SKU.objects.filter(id=1, stock=7).update(stock=2)
任務隊列
將下單的邏輯放到任務隊列中(如celery),將并行轉為串行,所有人排隊下單。比如開啟只有一個進程的Celery,一個訂單一個訂單的處理。
總結
以上所述是小編給大家介紹的django解決訂單并發問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。