久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

redis單線程需要加鎖的原因

134次閱讀
沒有評論

共計 912 個字符,預計需要花費 3 分鐘才能閱讀完成。

自動寫代碼機器人,免費開通

這篇文章將為大家詳細講解有關 redis 單線程需要加鎖的原因,丸趣 TV 小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

個人理解是,雖然 redis 是單線程,但是可以同時有多個客戶端訪問,每個客戶端會有一個線程。客戶端訪問之間存在競爭。

因為存在多客戶端并發,所以必須保證操作的原子性。比如銀行卡扣款問題,獲取余額,判斷,扣款,寫回就必須構成事務,否則就可能出錯。

在傳統單體應用單機部署的情況下,可以使用 Java 并發相關的鎖,如 ReentrantLcok 或 synchronized 進行互斥控制。但是,隨著業務發展的需要,原單體單機部署的系統,漸漸的被部署在多機器多 JVM 上同時提供服務,這使得原單機部署情況下的并發控制鎖策略失效了,為了解決這個問題就需要一種跨 JVM 的互斥機制來控制共享資源的訪問,這就是分布式鎖要解決的問題。

分布式鎖的實現條件

1、互斥性,和單體應用一樣,要保證任意時刻,只能有一個客戶端持有鎖

2、可靠性,要保證系統的穩定性,不能產生死鎖

3、一致性,要保證鎖只能由加鎖人解鎖,不能產生 A 的加鎖被 B 用戶解鎖的情況

Redis 實現分布式鎖不同的人可能有不同的實現邏輯。

分布式環境下,數據一致性問題一直是一個比較重要的話題,而又不同于單進程的情況。分布式與單機情況下最大的不同在于其不是多線程而是多進程。多線程由于可以共享堆內存,因此可以簡單的采取內存作為標記存儲位置。而進程之間甚至可能都不在同一臺物理機上,因此需要將標記存儲在一個所有進程都能看到的地方。

常見的是秒殺場景,訂單服務部署了多個實例。如秒殺商品有 4 個,第一個用戶購買 3 個,第二個用戶購買 2 個,理想狀態下第一個用戶能購買成功,第二個用戶提示購買失敗,反之亦可。而實際可能出現的情況是,兩個用戶都得到庫存為 4,第一個用戶買到了 3 個,更新庫存之前,第二個用戶下了 2 個商品的訂單,更新庫存為 2,導致出錯。

關于 redis 單線程需要加鎖的原因就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向 AI 問一下細節

丸趣 TV 網 – 提供最優質的資源集合!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-12-18發表,共計912字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 安平县| 韶关市| 南宫市| 长葛市| 仁寿县| 海城市| 嘉祥县| 松江区| 左权县| 游戏| 岗巴县| 宾阳县| 革吉县| 武义县| 石家庄市| 东源县| 海原县| 建阳市| 陆良县| 东海县| 蒙山县| 富宁县| 岳普湖县| 衡山县| 武隆县| 浠水县| 丹棱县| 韶山市| 德州市| 汝南县| 老河口市| 永年县| 酒泉市| 夏河县| 富蕴县| 鹿邑县| 额济纳旗| 屏东市| 堆龙德庆县| 香河县| 临夏市|