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

ZooKeeper官方文檔之Java案例解讀

 更新時間:2022年01月27日 14:59:25   作者:愛碼叔(稀有氣體)  
ZooKeeper官方提供了一個Java監(jiān)聽的例子,本文是我對該例子的學習筆記??梢宰鰹閹椭斫獯死拥馁Y料,有需要的朋友可以借鑒參考下

文檔原文連接:http://zookeeper.apache.org/doc/current/javaExample.html#sc_completeSourceCode

翻譯連接:http://www.dbjr.com.cn/article/236127.htm

需求理解

我們先回顧一下例子的需求,此客戶端有如下四個需求:

1、它接收如下參數(shù):

  • ZooKeeper服務的地址
  • 被監(jiān)控的znode的名稱
  • 可執(zhí)行命令參數(shù)

2、它會取得znode上關聯(lián)的數(shù)據(jù),然后執(zhí)行命令

3、如果znode變化,客戶端重新拉取數(shù)據(jù),再次執(zhí)行命令

4、如果znode消失了,客戶端殺掉進行的執(zhí)行命令

如果你已經(jīng)學習過或者了解過該例子文檔的內(nèi)容,你應該知道該程序做的事情就是接受用戶輸入的系統(tǒng)命令,然后監(jiān)控zookeeper的znode,一旦znode存在,或者發(fā)生了變化,程序會把znode最新的數(shù)據(jù)存入文件,然后起一個線程執(zhí)行用戶的命令,同時還會起兩個線程輸出執(zhí)行結果及日志。

舉例類比

為了幫助理解,這里舉個現(xiàn)實的例子--警察抓壞人:

公安成立了一個行動組準備在嫌疑人住所進行抓捕,警方人員安排如下:

  • 組長A負責總指揮
  • 警察B負責監(jiān)控嫌疑人,并與組長A聯(lián)絡
  • 警察C,D,E,F(xiàn)埋伏在嫌疑人住所前后左右,準備實施抓捕

整個抓捕過程是這樣的:

  • 組長A下達命令安排后,B,C各就各位(對象A做初始化工作)
  • B開始監(jiān)控嫌疑人,一旦嫌疑人進入警察布下的埋伏圈,則馬上通知組長A(對象B為watcher,嫌疑人為被監(jiān)聽的znode。A注冊為B的listener,在B的監(jiān)聽回調(diào)中被觸發(fā))
  • 組長A得到通知后,馬上命令C、D、E、F執(zhí)行抓捕。(C,D,E是被A調(diào)用干活的線程)

理解了上線的例子,我們繼續(xù)對程序進行講解。

Executor和DataMonitor

本例中有兩個主要類,職能如下:

Executor,它是程序的入口。負責初始化zookeeper、DataMonitor,把自己注冊為DataMonitor的監(jiān)聽者,一旦DataMonitor監(jiān)聽到變化后,會通知它執(zhí)行業(yè)務操作。

他是例子中的組長A,它有幾個內(nèi)部類是前面說的警員C、D、E、F,負責干活。

DataMonitor,他負責監(jiān)控znode,發(fā)現(xiàn)znode變化后,通知listener執(zhí)行業(yè)務邏輯,同時再次監(jiān)控znode:

他是例子中的警察B,負責監(jiān)控犯人,并通知A。

通過以上講解,這兩個主要類所負責的工作應該已經(jīng)可以充分的理解了。接下來我們針對這兩個類進入更為詳細的講解。

內(nèi)部類和接口

Executor:

        StreamWriter。繼承Thread,以多線程的形式負責把執(zhí)行的結果輸出。相當于例子中的警察C、D、E、F

DataMonitor:

        DataMonitorListener。DataMonitor一旦監(jiān)控到znode的變化,立即調(diào)用自己持有的listener(實現(xiàn)此接口的對象)的exists方法(通知它的監(jiān)聽者)。

繼承關系

Executor:

實現(xiàn)watcher:監(jiān)聽zookeeper連接的變化,實現(xiàn)process()方法,把事件傳遞給DataMonitor處理。 

實現(xiàn)DataMonitor中定義的接口DataListener: 實現(xiàn)exists()方法,處理znode變化的具體邏輯。

實現(xiàn)runnable類: run()方法中阻塞主線程,讓程序轉為事件驅動。

public class Executor implements Watcher, Runnable, DataMonitor.DataMonitorListener{}

DataMonitor:

實現(xiàn)watcher:

監(jiān)聽znode變化。實現(xiàn)process()方法,通過zk.exist()方法再次監(jiān)聽,再次設置自己為zookeeper.exist()的回調(diào)(實現(xiàn)不斷監(jiān)聽,事件驅動)。同時數(shù)據(jù)返回后,立即進入下面的回調(diào)函數(shù)處理

實現(xiàn)StatCallback:

這是zookeeper.exist()操作回調(diào)對象。實現(xiàn)processResult()方法,調(diào)用DataMonitor持有的listener(也就是Excutor)的exists()方法執(zhí)行邏輯。

public class DataMonitor implements Watcher, StatCallback{} 

引用關系

Executor:

  • DataMonitor dm;
  • ZooKeeper zk; //ZooKeeper的連接
  • Process child; //真正執(zhí)行系統(tǒng)命令的子線程,相當于警察C,D,E,F(xiàn)之一。

DataMonitor:

  • ZooKeeper zk; //和Executor是同一個引用。Executor通過構造函數(shù)傳入
  • DataMonitorListener listener; //executor對象,Executor通過構造函數(shù)傳入自己 

圖解

Executor和DataMonitor的關系如下:

兩者通過Executor作為主入口,初始化DataMonitor和ZooKeeper對象后,阻塞主線程。轉為事件驅動。即通過DataMonitor監(jiān)控znode上的事件來驅動程序邏輯。

整個流程如下:

  1. Excutor把自己注冊為DataMonitor的監(jiān)聽
  2. DataMonitor實現(xiàn)watcher接口,并監(jiān)聽znode
  3. znode變化時,觸發(fā)DataMonitor的監(jiān)聽回調(diào)
  4. 回調(diào)中通過ZooKeeper.exist() 再次監(jiān)聽znode
  5. 上一步exist的回調(diào)方法中,調(diào)用監(jiān)聽自己的Executor,執(zhí)行業(yè)務邏輯6
  6. Executor啟新的線程執(zhí)行命令
  7. Executor啟新的線程打印執(zhí)行命令的輸出

以上就是ZooKeeper官方文檔翻譯之Java例子解讀的詳細內(nèi)容,更多關于ZooKeeper文檔翻譯Java例子的資料請關注腳本之家其它相關文章!

相關文章

  • jmeter如何自動生成測試報告

    jmeter如何自動生成測試報告

    這篇文章主要介紹了jmeter如何自動生成測試報告,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-10-10
  • Java Swing實現(xiàn)讓窗體居中顯示的方法示例

    Java Swing實現(xiàn)讓窗體居中顯示的方法示例

    這篇文章主要介紹了Java Swing實現(xiàn)讓窗體居中顯示的方法,結合實例形式分析了swing使用setBounds方法控制窗口布局的相關操作技巧,需要的朋友可以參考下
    2017-11-11
  • Spring MVC登錄注冊以及轉換json數(shù)據(jù)

    Spring MVC登錄注冊以及轉換json數(shù)據(jù)

    本文主要介紹了Spring MVC登錄注冊以及轉換json數(shù)據(jù)的相關知識。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • SpringBoot資源文件的存放位置設置方式

    SpringBoot資源文件的存放位置設置方式

    這篇文章主要介紹了SpringBoot資源文件的存放位置設置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • 詳解maven的setting配置文件中mirror和repository的區(qū)別

    詳解maven的setting配置文件中mirror和repository的區(qū)別

    這篇文章主要介紹了詳解maven的setting配置文件中mirror和repository的區(qū)別,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • Spring RabbitMQ死信機制原理實例詳解

    Spring RabbitMQ死信機制原理實例詳解

    這篇文章主要介紹了Spring RabbitMQ死信機制原理實例詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-03-03
  • Java遍歷Map四種方式講解

    Java遍歷Map四種方式講解

    這篇文章主要介紹了Java遍歷Map四種方式講解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Java簡單計算圓周率完整示例

    Java簡單計算圓周率完整示例

    這篇文章主要介紹了Java簡單計算圓周率,結合完整實例形式分析了Java計算圓周率的原理與操作技巧,代碼備有較為詳盡的注釋便于理解,需要的朋友可以參考下
    2018-05-05
  • myBatis的mapper映射文件之批量處理方式

    myBatis的mapper映射文件之批量處理方式

    這篇文章主要介紹了myBatis的mapper映射文件之批量處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • 解析Flink內(nèi)核原理與實現(xiàn)核心抽象

    解析Flink內(nèi)核原理與實現(xiàn)核心抽象

    Flink API提供了開發(fā)的接口,此外,為了實現(xiàn)業(yè)務邏輯,還必須為開發(fā)者提供自定義業(yè)務邏輯的能力,下面為大家解析Flink內(nèi)核原理與實現(xiàn)核心抽象
    2021-08-08

最新評論