Java ZooKeeper分布式鎖實(shí)現(xiàn)圖解
什么是分布式鎖
1、在我們進(jìn)行單機(jī)應(yīng)用開發(fā),涉及并發(fā)同步的時(shí)候,我們往往采用synchronized或者Lock的方式來解決多線程間的代碼同步問題,這時(shí)多線程的運(yùn)行都是在同一個(gè)JVM之下,沒有任何問題。

2、但當(dāng)我們的應(yīng)用是分布式集群工作的情況下,屬于多JVM下的工作環(huán)境(多臺(tái)機(jī)器),跨JVM之間已經(jīng)無法通過多線程的鎖解決同步問題。那么就需要一種更加高級(jí)的鎖機(jī)制,來處理種跨機(jī)器的進(jìn)程之間的數(shù)據(jù)同步問題——這就是分布式鎖。(多節(jié)點(diǎn)從分布式組件中獲取鎖)

例如以下實(shí)例:

各種搶票軟件客戶端通過zookeeper獲取鎖,最終只有一個(gè)客戶端可以獲得鎖并且先與12306服務(wù)器進(jìn)行數(shù)據(jù)通信,最終和12306數(shù)據(jù)庫(kù)服務(wù)器通行。通信完畢之后釋放鎖,其他客戶端獲取鎖之后執(zhí)行同樣的操作。(顯然前提是這幾個(gè)客戶端都通過負(fù)載均衡后均與節(jié)點(diǎn)集群中同一個(gè)服務(wù)器進(jìn)行通信)
3、其他分布式鎖

zookeeper分布式鎖原理
核心思想:當(dāng)客戶端要獲取鎖,則創(chuàng)建節(jié)點(diǎn),使用完鎖,則刪除該節(jié)點(diǎn)。
1、客戶端獲取鎖時(shí),在lock節(jié)點(diǎn)下創(chuàng)建臨時(shí)順序節(jié)點(diǎn)。
2、然后獲取lock下面的所有子節(jié)點(diǎn),客戶端獲取到所有的子節(jié)點(diǎn)之后,如果發(fā)現(xiàn)自己創(chuàng)建的子節(jié)點(diǎn)序號(hào)最小,那么就認(rèn)為該客戶端獲取到了鎖。使用完鎖后,將該節(jié)點(diǎn)刪除。
注意:
創(chuàng)建臨時(shí)節(jié)點(diǎn)的原因:
如果某個(gè)已經(jīng)獲取鎖了的節(jié)點(diǎn)發(fā)生宕機(jī),如果是持久化節(jié)點(diǎn),那么鎖就無法釋放。如果是臨時(shí)節(jié)點(diǎn),在發(fā)生宕機(jī)后,連接斷開會(huì)自動(dòng)釋放鎖。
創(chuàng)建順序節(jié)點(diǎn)的原因:
將節(jié)點(diǎn)按順序編號(hào),客戶端通過節(jié)點(diǎn)編號(hào)判斷自己是否是序號(hào)最小的節(jié)點(diǎn),并且獲得鎖。

3、如果發(fā)現(xiàn)自己創(chuàng)建的節(jié)點(diǎn)并非lock所有子節(jié)點(diǎn)中最小的,說明自己還沒有獲取到鎖,此時(shí)客戶端需要找到比自己小的那個(gè)節(jié)點(diǎn),同時(shí)對(duì)其注冊(cè)事件監(jiān)聽器,監(jiān)聽刪除事件。

4、如果發(fā)現(xiàn)比自己小的那個(gè)節(jié)點(diǎn)被刪除,則客戶端的 Watcher會(huì)收到相應(yīng)通知,此時(shí)再次判斷自己創(chuàng)建的節(jié)點(diǎn)是否是lock子節(jié)點(diǎn)中序號(hào)最小的,如果是則獲取到了鎖, 如果不是則重復(fù)以上步驟繼續(xù)獲取到比自己小的一個(gè)節(jié)點(diǎn)并注冊(cè)監(jiān)聽。

到此這篇關(guān)于Java ZooKeeper分布式鎖實(shí)現(xiàn)圖解的文章就介紹到這了,更多相關(guān)Java ZooKeeper內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java中的static關(guān)鍵字用法總結(jié)
這篇文章主要介紹了Java中的static關(guān)鍵字用法總結(jié),static是Java50個(gè)關(guān)鍵字之一,static關(guān)鍵字可以用來修飾代碼塊表示靜態(tài)代碼塊,修飾成員變量表示全局靜態(tài)成員變量,修飾方法表示靜態(tài)方法,需要的朋友可以參考下2023-11-11
SpringBoot中注解實(shí)現(xiàn)定時(shí)任務(wù)的兩種方式
這篇文章主要介紹了SpringBoot中注解實(shí)現(xiàn)定時(shí)任務(wù)的兩種方式,SpringBoot 定時(shí)任務(wù)是一種在SpringBoot應(yīng)用中自動(dòng)執(zhí)行任務(wù)的機(jī)制,通過使用Spring框架提供的@Scheduled注解,我們可以輕松地創(chuàng)建定時(shí)任務(wù),需要的朋友可以參考下2023-10-10
Java實(shí)現(xiàn)的簡(jiǎn)單畫圖板示例
這篇文章主要介紹了Java實(shí)現(xiàn)的簡(jiǎn)單畫圖板,涉及java使用swing組件進(jìn)行圖形繪制相關(guān)操作技巧,需要的朋友可以參考下2018-08-08
Spring Boot中的JdbcTemplate是什么及用法小結(jié)
Spring Boot中的JdbcTemplate是一個(gè)強(qiáng)大的數(shù)據(jù)庫(kù)訪問工具,它簡(jiǎn)化了數(shù)據(jù)庫(kù)操作的過程,在本文中,我們了解了JdbcTemplate的基本概念,并演示了如何在Spring Boot應(yīng)用程序中使用它,感興趣的朋友跟隨小編一起看看吧2023-10-10
Mybatis 級(jí)聯(lián)刪除的實(shí)現(xiàn)
這篇文章主要介紹了Mybatis 級(jí)聯(lián)刪除的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
Java過濾器filter_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了Java過濾器filter,通過過濾器,可以對(duì)來自客戶端的請(qǐng)求進(jìn)行攔截,進(jìn)行預(yù)處理或者對(duì)最終響應(yīng)給客戶端的數(shù)據(jù)進(jìn)行處理后再輸出2017-07-07

