欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java ZooKeeper分布式鎖實(shí)現(xiàn)圖解

 更新時(shí)間:2022年03月01日 14:37:41   作者:GuochaoHN  
ZooKeeper是一個(gè)分布式的,開(kāi)放源碼的分布式應(yīng)用程序協(xié)調(diào)服務(wù),是Google的Chubby一個(gè)開(kāi)源的實(shí)現(xiàn),是Hadoop和Hbase的重要組件。它是一個(gè)為分布式應(yīng)用提供一致性服務(wù)的軟件,提供的功能包括:配置維護(hù)、域名服務(wù)、分布式同步、組服務(wù)等

什么是分布式鎖

1、在我們進(jìn)行單機(jī)應(yīng)用開(kāi)發(fā),涉及并發(fā)同步的時(shí)候,我們往往采用synchronized或者Lock的方式來(lái)解決多線程間的代碼同步問(wèn)題,這時(shí)多線程的運(yùn)行都是在同一個(gè)JVM之下,沒(méi)有任何問(wèn)題。

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

例如以下實(shí)例:

各種搶票軟件客戶端通過(guò)zookeeper獲取鎖,最終只有一個(gè)客戶端可以獲得鎖并且先與12306服務(wù)器進(jìn)行數(shù)據(jù)通信,最終和12306數(shù)據(jù)庫(kù)服務(wù)器通行。通信完畢之后釋放鎖,其他客戶端獲取鎖之后執(zhí)行同樣的操作。(顯然前提是這幾個(gè)客戶端都通過(guò)負(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),那么鎖就無(wú)法釋放。如果是臨時(shí)節(jié)點(diǎn),在發(fā)生宕機(jī)后,連接斷開(kāi)會(huì)自動(dòng)釋放鎖。

創(chuàng)建順序節(jié)點(diǎn)的原因:

將節(jié)點(diǎn)按順序編號(hào),客戶端通過(guò)節(jié)點(diǎn)編號(hào)判斷自己是否是序號(hào)最小的節(jié)點(diǎn),并且獲得鎖。

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

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)聽(tīng)。

到此這篇關(guān)于Java ZooKeeper分布式鎖實(shí)現(xiàn)圖解的文章就介紹到這了,更多相關(guān)Java ZooKeeper內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java中stream.map和stream.forEach的區(qū)別

    Java中stream.map和stream.forEach的區(qū)別

    本文主要介紹了Java中stream.map和stream.forEach的區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • 理解JPA注解@GeneratedValue的使用方法

    理解JPA注解@GeneratedValue的使用方法

    這篇文章主要介紹了理解JPA注解@GeneratedValue的使用方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07
  • 只需兩步實(shí)現(xiàn)Eclipse+Maven快速構(gòu)建第一個(gè)Spring Boot項(xiàng)目

    只需兩步實(shí)現(xiàn)Eclipse+Maven快速構(gòu)建第一個(gè)Spring Boot項(xiàng)目

    這篇文章主要介紹了只需兩步實(shí)現(xiàn)Eclipse+Maven快速構(gòu)建第一個(gè)Spring Boot項(xiàng)目,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • mybatis?對(duì)于生成的sql語(yǔ)句?自動(dòng)加上單引號(hào)的情況詳解

    mybatis?對(duì)于生成的sql語(yǔ)句?自動(dòng)加上單引號(hào)的情況詳解

    這篇文章主要介紹了mybatis?對(duì)于生成的sql語(yǔ)句?自動(dòng)加上單引號(hào)的情況詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 數(shù)據(jù)結(jié)構(gòu)與算法之手撕排序算法

    數(shù)據(jù)結(jié)構(gòu)與算法之手撕排序算法

    排序算法看似簡(jiǎn)單,其實(shí)不同的算法中蘊(yùn)涵著經(jīng)典的算法策略。通過(guò)熟練掌握排序算法,就可以掌握基本的算法設(shè)計(jì)思想,本文主要介紹了Java中的排序算法,需要的朋友歡迎閱讀
    2023-04-04
  • 使用Backoff策略提高HttpClient連接管理的效率

    使用Backoff策略提高HttpClient連接管理的效率

    這篇文章主要為大家介紹了Backoff策略提高HttpClient連接管理的效率使用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • Java文件(io)編程_基于File類的基本用法(必看篇)

    Java文件(io)編程_基于File類的基本用法(必看篇)

    下面小編就為大家?guī)?lái)一篇Java文件(io)編程_基于File類的基本用法(必看篇)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • 阿里、華為、騰訊Java技術(shù)面試題精選

    阿里、華為、騰訊Java技術(shù)面試題精選

    這篇文章主要為大家分享了阿里、華為、騰訊Java技術(shù)面試題精選,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Springmvc基于fastjson實(shí)現(xiàn)導(dǎo)包及配置文件

    Springmvc基于fastjson實(shí)現(xiàn)導(dǎo)包及配置文件

    這篇文章主要介紹了Springmvc基于fastjson實(shí)現(xiàn)導(dǎo)包及配置文件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • Springboot?定時(shí)任務(wù)分布式下冪等性解決方案

    Springboot?定時(shí)任務(wù)分布式下冪等性解決方案

    這篇文章主要介紹了Springboot定時(shí)任務(wù)分布式下冪等性如何解決,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07

最新評(píng)論