老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

如何進行Zookeeper分布式鎖的代碼實現-創新互聯

這期內容當中小編將會給大家帶來有關如何進行Zookeeper分布式鎖的代碼實現,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:申請域名、虛擬空間、營銷軟件、網站建設、西鄉網站維護、網站推廣。

前言

Zookeeper分布式鎖的代碼實現

在上一篇博客中,從思路上已經分析了Zookeeper如何幫助我們實現分布式鎖,我們直接來看代碼:

[分布式客戶端]

如何進行Zookeeper分布式鎖的代碼實現

[獲取分布式鎖的方法lock:初始化ZK]

如何進行Zookeeper分布式鎖的代碼實現

[獲取分布式鎖的方法lock:創建臨時節點與判斷最小路徑]

如何進行Zookeeper分布式鎖的代碼實現

[main測試]

如何進行Zookeeper分布式鎖的代碼實現

[運行結果]

如何進行Zookeeper分布式鎖的代碼實現

需要注意的是,即便監控到了比自己序號小的節點的刪除Watcher,也需要再次確認下!

從結果上,看的很清楚,各個線程有序獲得鎖。

zkclient

zkclient是在zookeeper原生API基礎上做了一點封裝,簡化了ZK的復雜性。

來看代碼:

如何進行Zookeeper分布式鎖的代碼實現

我們觀察下zkclient的使用,和以前基于zookeeper的原生API有哪些區別呢?

第一,原生API需要我們利用CountDownLatch來確保ZK的初始化,現在zkclient幫助我們屏蔽掉了這個細節

第二,原生API是不可以遞歸創建節點的,而zkclient可以幫助我們遞歸創建不存在的父節點,還可以遞歸刪除

第三,支持序列化操作,上面的代碼你大概可以看出一些端倪,就是我們從操作byte[]到操作String了。(事實上,在zkclient中你只需要實現ZkSerializer接口,就可以完成Object到byte[]的轉換,雖然如此,但是實際開發中,利用JSON也挺好的!)

第四,還有最重要的一點就是,zkclient將對節點的操作和對節點的監控分離開了,在原生API中2者是耦合在一起的!從思想上來看,便于理解;從代碼上來看,也簡潔些(如果寫在一起,頭都大了);更加方便的是,zkclient替我們完成了重復watch的功能!

[watch訂閱機制]

如何進行Zookeeper分布式鎖的代碼實現

看到沒有,是不是有點像MQ的訂閱機制,非常好用!【但是也有點不太完美,子節點的數據變更為什么沒有監控呢,這有點不符合人性啊!還好有Curator...】

但是呢,我們知道ZK是有很多應用場景的,比如實現分布式鎖,zkclient并沒有替我們進行封裝,但是Curator框架可以幫助我們做到!

Curator

為了更好實現Java操作Zookeeper服務器,后來出現Curator框架,功能非常強大,目前已經是Apache的頂級項目,有很多豐富的特性,比如session超時重連,主從選舉,分布式計數器,分布式鎖等,非常有利于Zookeeper復雜場景下的開發。

POM文件:

如何進行Zookeeper分布式鎖的代碼實現

增刪改查:

如何進行Zookeeper分布式鎖的代碼實現Curator框架使用鏈式編程風格,易讀性很強!

注意,不論是原生的API,還是基于zkclient的API,都是提供的connectTimeout,而Curator提供了sessionTimeout,功能很強大。

如何進行Zookeeper分布式鎖的代碼實現

無論是原生的API,還是zkclient,都是支持異步回調的,但是Curator框架在支持異步回調的同時,增加了線程池供我們優化!

[NodeCacheListener]

如何進行Zookeeper分布式鎖的代碼實現

[PathChildrenCacheListener]

如何進行Zookeeper分布式鎖的代碼實現

對于Curator而言,為了解決重復Watch的問題,它引入了一種全新的思想:Cache與ZK SERVER比對的機制。不論是原生的API,還是基于ZKCLIENT的,其實它們解決思路都是重復注冊!

思路決定出路!Curator通過事件驅動將客戶端的Cache與ZK SERVER的數據比對,就自然而然的解決了重復WATCH的功能!為什么Curator能成為Apache的頂級項目呢,我想大概就是因為它的與眾不同的設計思想!

在Curator中,有2種Listener,一個是監控節點的NodeCacheListener,一個是監控子節點的PathChildrenCacheListener。PathChildernCacheListener可以監控子節點的新增、修改、刪除,非常好用!

上述就是小編為大家分享的如何進行Zookeeper分布式鎖的代碼實現了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注創新互聯行業資訊頻道。

另外有需要云服務器可以了解下創新互聯cdcxhl.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


文章題目:如何進行Zookeeper分布式鎖的代碼實現-創新互聯
標題URL:http://www.xueling.net.cn/article/csshgj.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 国产午夜一级在线观看影院 | 日韩色悠悠| 精品无人乱码一区二区三区 | 大内密探零零性在线 | a级毛片免费观看在线播放 日本免费一区二区三区视频 | 精品久久久国产精品999 | 中文字幕无线码一区2020青青 | 美女在线一区二区 | 程视频精品视频一区二区三区欧 | 一区二区三区视频在线播放 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 日韩精品人妻系列无码专区 | 高清视频一区二区 | 99热这里只有成人精品国产 | 999久久久欧美日韩黑人 | 青苹果乐园高清免费看 | 精品美女一区二区 | 久青草国产97香蕉在线视频 | av在线资源播放 | 四虎成人在线视频 | 亚洲AV永久无码精品天堂动漫 | 日本免费极度色诱福利视频 | 先锋影音人妻啪啪va资源网站 | 亚洲AV成人一区二区三区观看在线 | 永夜星河在线免费观看 | 久久青青草原国产精品最新片 | 高清国产AV一区二区三区 | 神偷奶爸4中文版免费观看 国产黄色大片在线观看 | 少妇被又粗又里进进出出 | 国产精品久久久久久久久亚洲美女 | 观看麻豆视频 | 一个人免费观看视频WWW中文 | 中文字幕亚洲乱码熟女在线萌芽 | 免费无码一级成年片在线观看 | 37pao成人永久免费视频 | 好想被狂躁无码视频在线观看 | 国产专区中文字幕 | 国产三级爽死你久久精品 | 一区二区在线 | 久久精品娱乐亚洲领先 | 神马久久免费视频 |