理解主從設備模式(Master-Slave)

来源:https://www.cnblogs.com/dmego/archive/2018/05/21/9068734.html
-Advertisement-
Play Games

前言 在給定上下文的軟體體繫結構中,為瞭解決某些經常出現的問題而形成的通用且可重用的解決方案稱之為架構模式,而常見的體系架構模式主要有以下十種 分層模式 客戶端 伺服器模式 主從設備模式 管道 過濾器模式 代理模式 點對點模式 事件匯流排模式 模型 視圖 控制器模式 黑板模式 解釋器模式 而下麵我將詳 ...


前言

在給定上下文的軟體體繫結構中,為瞭解決某些經常出現的問題而形成的通用且可重用的解決方案稱之為架構模式,而常見的體系架構模式主要有以下十種

  • 分層模式
  • 客戶端-伺服器模式
  • 主從設備模式
  • 管道-過濾器模式
  • 代理模式
  • 點對點模式
  • 事件匯流排模式
  • 模型-視圖-控制器模式
  • 黑板模式
  • 解釋器模式

而下麵我將詳細介紹主從設備模式的概念,以及它的用法、在實際中常見的應用場景和優缺點等

主從設備模式

主從設備模式也叫做主僕模式英文簡稱為Master-Slave,核心思想是基於分而治之的思想,將一個原始任務分解為若幹個語義等同的子任務,並由專門的工作者線程來並行執行這些任務,原始任務的結果是通過整合各個子任務的處理結果形成的.主要的使用場景有

  • 並行計算,以提升計算性能
  • 容錯處理,以提升計算的可靠性
  • 計算精度,以提高計算的精確程度

並行計算下模式舉例

在分散式的系統中,這個模式還是比較常用的,簡單的說,主從(Master-Slave)進程-線程的關係類似,Master只有一臺機器作為Master,其他機器作為Slave,這些機器同時運行組成了集群.Master作為任務調度者,給多個Slave分配計算任務,當所有的Slave將任務完成之後,最後由Master彙集結果,這個其實也是MapReduce思想所在.
mark
例如在Hadoop中,HDFS採用了基於Master/Slave主從架構的分散式文件系統,一個HDFS集群包含一個單獨的Master節點和多個Slave節點伺服器,這裡的一個單獨的Master節點的含義是HDFS系統中只存在一個邏輯上的Master組件。一個邏輯的Master節點可以包括兩台物理主機,即兩台Master伺服器、多台Slave伺服器。一臺Master伺服器組成單NameNode集群,兩台Master伺服器組成雙NameNode集群,並且同時被多個客戶端訪問,所有的這些機器通常都是普通的Linux機器,運行著用戶級別(user-level)的服務進程.

在上圖中展示了 HDFS 的 NameNode , DataNode 以及客戶端之間的存取訪問關係, NameNode 作為 Master 服務,它負責管理文件系統的命名空間和客戶端對文件的訪問。NameNode會保存文件系統的具體信息,包括文件信息、文件被分割成具體block塊的信息、以及每一個block塊歸屬的DataNode的信息。對於整個集群來說,HDFS通過NameNode對用戶提供了一個單一的命名空間。DataNode作為slave服務,在集群中可以存在多個。通常每一個DataNode都對應於一個物理節點。DataNode負責管理節點上它們擁有的存儲,它將存儲劃分為多個block塊,管理block塊信息,同時周期性的將其所有的block塊信息發送給NameNode

優缺點

  • 優點:準確性——將服務的執行委托給不同的從設備,具有不同的實現。
  • 缺點:從設備是孤立的,沒有共用的狀態。主-從通信中的延遲可能是一個問題,例如在實時系統中。這種模式只能應用於可以分解的問題。

參考


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

-Advertisement-
Play Games
更多相關文章
  • __proto__、prototype傻傻分不清楚? 記住以下兩點:1.__proto__是每個對象都有的一個屬性,而prototype是函數才會有的屬性。2.__proto__指向的是當前對象的原型對象,而prototype指向的,是以當前函數作為構造函數構造出來的對象的原型對象 (寫在最前面,轉 ...
  • 深入css佈局(2) — 定位與浮動 在css知識體系中,除了css選擇器,樣式屬性等基礎知識外,css佈局相關的知識才是css比較核心和重要的點。今天我們來深入學習一下css佈局相關的知識。 上篇文章我們講完了css佈局中盒模型和元素分類的相關知識,同時介紹了box-sizing和行框。這篇我們繼 ...
  • 一 JS中有哪些數據類型? -- 共 6 種數據類型,其中 5 種基本數據類型Undefined,Null,Boolean,Number和 String,1 種複雜數據類型Object。因為ECMAScript不支持創建任何自定義的類型,所以最終所有的類型都是其中 6 種數據類型之一。(ES6中新增 ...
  • <el-table :data="tableData" stripe border style="width:100%" highlight-current-row> <el-table-column type="selection" width="55"> </el-table-column> < ...
  • 經實驗,$.serializeArray()獲取不到disabled的值,如果想要讓input元素變為不可用,可以把input設為readonly,而不是disabled; 還有一種情況獲取不到值,當頁面中有兩個一樣name值的標簽的時候,即使其中一個name值的input的樣式為 display: ...
  • 前段時間有朋友私信我 Vue + TypeScript 的問題,然後就打算寫一篇 Vue + TypeScript 封裝組件的文章 正好公司項目中需要封裝一個表頭查詢組件,就拿出來分享一下~ 組件的整體思路是通過一個 config 數組生成列表的頭部表單: PS:配合《Vue 爬坑之路(九)—— 用 ...
  • 相關文章: "ELK 架構之 Elasticsearch 和 Kibana 安裝配置" "ELK 架構之 Logstash 和 Filebeat 安裝配置" ELK 使用步驟:Spring Boot 日誌輸出到指定目錄,Filebeat 進行採集,Logstash 進行過濾,Elasticsearc ...
  • 一、什麼是享元模式 說到享元模式,第一個想到的應該就是池技術了,String常量池、資料庫連接池、緩衝池等等都是享元模式的應用,所以說享元模式是池技術的重要實現方式。 比如我們每次創建字元串對象時,都需要創建一個新的字元串對象的話,記憶體開銷會很大,所以如果第一次創建了字元串對象“adam“,下次再創 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...