Java ZooKeeper分布式鎖實現(xiàn)圖解
什么是分布式鎖
1、在我們進行單機應(yīng)用開發(fā),涉及并發(fā)同步的時候,我們往往采用synchronized或者Lock的方式來解決多線程間的代碼同步問題,這時多線程的運行都是在同一個JVM之下,沒有任何問題。
2、但當(dāng)我們的應(yīng)用是分布式集群工作的情況下,屬于多JVM下的工作環(huán)境(多臺機器),跨JVM之間已經(jīng)無法通過多線程的鎖解決同步問題。那么就需要一種更加高級的鎖機制,來處理種跨機器的進程之間的數(shù)據(jù)同步問題——這就是分布式鎖。(多節(jié)點從分布式組件中獲取鎖)
例如以下實例:
各種搶票軟件客戶端通過zookeeper獲取鎖,最終只有一個客戶端可以獲得鎖并且先與12306服務(wù)器進行數(shù)據(jù)通信,最終和12306數(shù)據(jù)庫服務(wù)器通行。通信完畢之后釋放鎖,其他客戶端獲取鎖之后執(zhí)行同樣的操作。(顯然前提是這幾個客戶端都通過負載均衡后均與節(jié)點集群中同一個服務(wù)器進行通信)
3、其他分布式鎖
zookeeper分布式鎖原理
核心思想:當(dāng)客戶端要獲取鎖,則創(chuàng)建節(jié)點,使用完鎖,則刪除該節(jié)點。
1、客戶端獲取鎖時,在lock節(jié)點下創(chuàng)建臨時順序節(jié)點。
2、然后獲取lock下面的所有子節(jié)點,客戶端獲取到所有的子節(jié)點之后,如果發(fā)現(xiàn)自己創(chuàng)建的子節(jié)點序號最小,那么就認為該客戶端獲取到了鎖。使用完鎖后,將該節(jié)點刪除。
注意:
創(chuàng)建臨時節(jié)點的原因:
如果某個已經(jīng)獲取鎖了的節(jié)點發(fā)生宕機,如果是持久化節(jié)點,那么鎖就無法釋放。如果是臨時節(jié)點,在發(fā)生宕機后,連接斷開會自動釋放鎖。
創(chuàng)建順序節(jié)點的原因:
將節(jié)點按順序編號,客戶端通過節(jié)點編號判斷自己是否是序號最小的節(jié)點,并且獲得鎖。
3、如果發(fā)現(xiàn)自己創(chuàng)建的節(jié)點并非lock所有子節(jié)點中最小的,說明自己還沒有獲取到鎖,此時客戶端需要找到比自己小的那個節(jié)點,同時對其注冊事件監(jiān)聽器,監(jiān)聽刪除事件。
4、如果發(fā)現(xiàn)比自己小的那個節(jié)點被刪除,則客戶端的 Watcher會收到相應(yīng)通知,此時再次判斷自己創(chuàng)建的節(jié)點是否是lock子節(jié)點中序號最小的,如果是則獲取到了鎖, 如果不是則重復(fù)以上步驟繼續(xù)獲取到比自己小的一個節(jié)點并注冊監(jiān)聽。
到此這篇關(guān)于Java ZooKeeper分布式鎖實現(xiàn)圖解的文章就介紹到這了,更多相關(guān)Java ZooKeeper內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java中stream.map和stream.forEach的區(qū)別
本文主要介紹了Java中stream.map和stream.forEach的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08只需兩步實現(xiàn)Eclipse+Maven快速構(gòu)建第一個Spring Boot項目
這篇文章主要介紹了只需兩步實現(xiàn)Eclipse+Maven快速構(gòu)建第一個Spring Boot項目,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12mybatis?對于生成的sql語句?自動加上單引號的情況詳解
這篇文章主要介紹了mybatis?對于生成的sql語句?自動加上單引號的情況詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01數(shù)據(jù)結(jié)構(gòu)與算法之手撕排序算法
排序算法看似簡單,其實不同的算法中蘊涵著經(jīng)典的算法策略。通過熟練掌握排序算法,就可以掌握基本的算法設(shè)計思想,本文主要介紹了Java中的排序算法,需要的朋友歡迎閱讀2023-04-04使用Backoff策略提高HttpClient連接管理的效率
這篇文章主要為大家介紹了Backoff策略提高HttpClient連接管理的效率使用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10Java文件(io)編程_基于File類的基本用法(必看篇)
下面小編就為大家?guī)硪黄狫ava文件(io)編程_基于File類的基本用法(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08Springmvc基于fastjson實現(xiàn)導(dǎo)包及配置文件
這篇文章主要介紹了Springmvc基于fastjson實現(xiàn)導(dǎo)包及配置文件,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-10-10Springboot?定時任務(wù)分布式下冪等性解決方案
這篇文章主要介紹了Springboot定時任務(wù)分布式下冪等性如何解決,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07