1、本項目從抽象到實現闡述了如何利用redis實現分布式鎖,完成簡單的秒殺功能 2、項目主要用到的redis鎖的概念 秒殺中需要考慮的問題點: 1、既然有并發問題,那我就讓他“不并發”,將所有的線程用一個隊列管理起來,使之變成串行操作,自然不會有并發問題。 2、秒殺在技術層面的抽象應該就是一個方法,在這個方法里可能的操作是將商品庫存-1,將商品加入用戶的購物車等等,在不考慮緩存的情況下應該是要操作數據庫的。那么最簡單直接的實現就是在這個方法上加上synchronized關鍵字,通俗的講就是鎖住整個方法; 3、鎖住整個方法這個策略簡單方便,但是似乎有點粗暴。可以稍微優化一下,只鎖住秒殺的代碼塊,比如寫數據庫的部分; |