(原)3.1 Zookeeper應用 - Master選舉

来源:http://www.cnblogs.com/shengkejava/archive/2016/08/01/5726794.html
-Advertisement-
Play Games

本文為原創文章,轉載請註明出處,謝謝 Master 選舉 1、原理 伺服器爭搶創建標誌為Master的臨時節點 伺服器監聽標誌為Master的臨時節點,當監測到節點刪除事件後展開新的一輪爭搶 某個伺服器成功創建則為Master 2、架構圖 Master:伺服器爭搶節點 Servers:伺服器列表節點 ...


本文為原創文章,轉載請註明出處,謝謝

Master 選舉

1、原理

  • 伺服器爭搶創建標誌為Master的臨時節點
  • 伺服器監聽標誌為Master的臨時節點,當監測到節點刪除事件後展開新的一輪爭搶
  • 某個伺服器成功創建則為Master

2、架構圖

  • Master:伺服器爭搶節點
  • Servers:伺服器列表節點
  • work Server:伺服器節點

3、流程圖

 

 4、核心代碼

  • workServer監聽
        public WorkServer(final ServerData serverData) {
            this.serverData = serverData;
            dataListener = new IZkDataListener() {
                @Override
                public void handleDataChange(String s, Object o) throws Exception {
    
                }
    
                @Override
                public void handleDataDeleted(String s) throws Exception {
    
                    //toBeMaster();
                    //適應網路抖動
                    if(null!=masterData && masterData.getName().equals(serverData.getName())) {
                        toBeMaster();
                    }else{
                        executorService.schedule(new Runnable() {
                            @Override
                            public void run() {
                                toBeMaster();
                            }
                        },10, TimeUnit.SECONDS);
                    }
                }
            };
        }
    適應網路抖動:當網路發生異常可能會出現短時間的斷開,發生此情況時給予節點創建的延時,如果上次保存Master信息為當前節點,則此次Master節點爭搶會有10秒鐘的優勢
  • 爭搶Master
    public void toBeMaster() {
    
            if(!running) return;
            //創建臨時節點,session連接失敗自動刪除
    
            try{
                zkClient.create(MASTER_NOTE,serverData, CreateMode.EPHEMERAL);
                masterData = serverData;
                System.out.println("當前master:"+masterData.getName());
    
                //測試使用,每5秒釋放master節點
                if(checkMaster()) {
                    executorService.schedule(new Runnable() {
                        @Override
                        public void run() {
                            releaseMaster();
                        }
                    },detay,TimeUnit.SECONDS);
                }
    
            }catch (ZkNodeExistsException e){
                //如果master節點已經存在 讀取
                ServerData data = zkClient.readData(MASTER_NOTE,true);
    
                //數據為空說明此時master 宕機
                if(null==data){
                    toBeMaster();
                }else{
                    masterData = data;
                }
            }
    
        }
    • ZkNodeExistsException :說明已存在Master節點
    •   存在後讀取節點數據,如果節點數據不存在則說明此時Master宕機,進行爭搶

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 橋接模式的定義: 將抽象化(Abstraction)與實現化(Implementation)脫耦,使得二者可以獨立地變化。 橋接模式結構圖: 橋接模式中得角色: 抽象化(Abstraction)角色:抽象化給出的定義,並保存一個對實現化對象的引用。 修正抽象化(Refined Abstraction ...
  • 1. 理解MVC MVC是一種經典的設計模式,全名為Model-View-Controller,即模型-視圖-控制器。 其中,模型是用於封裝數據的載體,例如,在Java中一般通過一個簡單的POJO(Plain Ordinary Java Object)來表示,其本質是一個普通的Java Bean,包 ...
  • 1.用法示例1 String str = QString("%1 %2 %3 %4 %5 %6 %7 %8 %9 %10 %11").arg("1","2","3","4","5","6","7","8","9"); qDebug() << str << endl; 輸出 "1 2 3 4 5 6 ...
  • 分散式事務與本地事務一樣,包含原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)和持久性(Durability)。兩階段提交是保證分散式事務中原子性的重要方法。本文重點介紹了兩階段提交的原理,PostgreSQL中兩階段提交介面,以及Java中兩階段提交介面... ...
  • 一、概述 單例模式確保一個類只有一個實例,並提供一個安全的訪問點。 二、解決問題 從概述中我們知道,單例模式就是保證系統的一個類只有一個實例。它的作用就是控制受限資源的訪問,確保任何時刻都只有一個線程在訪問一個受保護的資源。或者確保行為和狀態的一致性,避免異常行為。在java web的程式中可能用到 ...
  • 今天打算寫寫關於 IM 去中心化涉及的架構模型變化和設計思路,去中心化的概念就是說用戶的訪問不是集中在一個數據中心,這裡的去中心是針對數據中心而言的。 站在這個角度而言,實際上並非所有的業務都能做去中心化設計,對於一致性要求越高的業務去中心化越難做。比如電商領域的庫存就是一個對一致性要求很高的業務, ...
  • uml類圖的六大關係:泛化(Generalization)、實現(Realization)、關聯(Association)、聚合(Aggregation)、組合(Composition)、依賴(Dependency) ...
  • 代理設計模式:Proxy Pattern。在真實對象與客戶端對象之間加入一層中階層,由這一 層中介來完成對真實對象的引用。 優點:可以讓程式的業務邏輯更加清晰。客戶端對象不需要瞭解真實對象的細節,所有 的調用均由代理來完成。擴展性更高。代理保護了真實對象。 常用的場景: 1. 遠程代理:為一個位於不 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...