《分散式技術原理與演算法解析》學習筆記Day11

来源:https://www.cnblogs.com/wing011203/archive/2023/02/14/17121016.html
-Advertisement-
Play Games

這篇文章繼續討論分散式架構中的調度演算法,為瞭解決單體調度面臨的問題,我們引入兩層調度。我們會討論兩層調度的工作原理,兩種使用了兩層調度的解決方案:Apache Mesos和Hadoop YARN。 ...


調度框架:兩層調度

為什麼會有兩層調度?

單體調度的核心是所有節點的資源以及用戶的任務均由中央伺服器統一管理和調度,這樣中央伺服器容易成為單點瓶頸。

為了提升調度效率並支持多種類型的任務,我們可以嘗試把資源和任務分開調度,也就是說一層調度器負責資源管理和分配,另一層調度器負責任務與資源的匹配。

兩層調度結構對應的是兩層調度器,資源的使用情況同時由中央調度器和第二層調度器管理,中央調度器從整體上進行資源的管理和分配,將資源分配到第二層調度器,再由第二層調度器負責將資源與具體的任務匹配。

兩層調度的詳細結構圖如下。

兩層調度器中的第一層調度器仍是一個經過簡化的中央調度器,通常放在分散式集群管理系統中,而第二層調度則是由各個應用程式框架完成。兩層調度器的職責:

  • 第一層調度器負責管理資源並向框架分配資源。
  • 第二層調度器接收分散式集群管理系統中第一層調度器分配的資源,然後根據任務和接收到的資源進行分配。

常見的常用了兩層調度結構的集群管理系統有:

  1. Apache Mesos
  2. Hadoop YARN

Mesos中的兩層調度設計

Mesos本身實現的調度器是第一層調度,負責資源管理,第二層調度交給了應用框架來完成。

以Mesos為基礎的分散式資源管理與調度框架包括兩部分:

  1. 資源管理集群,由一個Master節點和多個Slave節點組成的集中式系統,它由一個Master節點,負責管理Slave節點,並對接上層框架,Slave節點向Master節點周期彙報資源狀態信息,並執行框架提交的任務。
  2. 框架,負責應用管理和調度的“組件“,它主要由調度器和執行器組成,調度器可以從Master節點獲取集群節點的信息,執行器在Slave節點上執行任務。

Mesos兩層調度的基本原理:

  1. 框架向Mesos Master註冊。
  2. Mesos Slave節點定期向Mesos Master上報本節點的空閑資源。
  3. Mesos Master的Scheduler進程收集所有節點的空閑資源信息,並以Resource Offer的方式將空閑的資源發送給註冊的框架。
  4. 框架的Scheduler接收到Mesos發送的資源後,進行任務調度和匹配,匹配成功後,將匹配結構下發給Mesos Master,並由Mesos Master轉發給相應節點的執行器執行任務。

Resource Offer機制是指Mesos Master主動將節點空閑資源以類似發放的方式發給每個框架,如果框架需要則使用,不需要則返回。

通過Resource Offer機制,第一層調度將資源主動告知第二層調度,然後第二層調度進行具體的任務分配,從而實現了任務調度與資源管理的分離,Mesos Master通過資源分配演算法決定給各個Framework提供多少資源,而Framework決定了接受哪些資源,以及哪些任務使用這些資源運行。

在調度中,常見的資源分配演算法包括:

  1. 最大最小公平演算法
  2. 主導資源公平演算法

最大最小公平演算法是一種在兼顧公平的前提上,儘可能讓更多滿意的資源分配演算法。這個演算法有3個主要原則:

  1. 按照用戶對資源資源需求量遞增的順序進行空閑資源分配。
  2. 不存在用戶得到的資源超過了自己需求的情況。
  3. 對於分配資源不滿足需求的用戶,所獲得的資源是相等的。

主導資源公平演算法在考慮絕對公平的前提下,還考慮了用戶對不同類型的需求,以可能得合理分配資源,即主導資源公平演算法可以儘可能的滿足更多用戶。

最大最小公平演算法適用於單一類型的資源分配場景,而主導資源公平演算法適用於多種類型的混合場景。並且最大最小演算法從公平的角度出發。為了每個用戶分配不多於與需求量的資源,而主導資源公平演算法從任務出發,目的在於充分儘量利用資源使得能夠執行的任務越多越好。

    作者:李潘     出處:http://wing011203.cnblogs.com/     本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 字元串解讀 es6加強了對Unicode 的支持,允許\uxxxx的形式展現一個字元,例如: console.log('\u0061'); // 列印 a \u後面的為字元的 Unicode 碼點 \u 後面4位 xxxx 但是這種寫法只識別 \u0000 到 \UFFFF 之間的字元,超出需要使用 ...
  • 閱識風雲是華為雲信息大咖,擅長將複雜信息多元化呈現,其出品的一張圖(雲圖說)、深入淺出的博文(雲小課)或短視頻(雲視廳)總有一款能讓您快速上手華為雲。更多精彩內容請單擊此處。 摘要:本篇雲小課主要指導使用Springboot應用的用戶,快速部署業務到函數工作流FunctionGraph服務。 本文分 ...
  • 我們是袋鼠雲數棧 UED 團隊,致力於打造優秀的一站式數據中台產品。我們始終保持工匠精神,探索前端道路,為社區積累並傳播經驗價值。 前言 單元測試是一種用於測試“單元”的軟體測試方法,其中“單元”的意思是指軟體中各個獨立的組件或模塊。開發者需要為他們的代碼編寫測試用例以確保這些代碼可以正常使用。 在 ...
  • 這是一個投資80億的智能化的稀土廠區規劃項目,2023年年前與該項目的一號負責人進行彙報與交流,年後雙方人員進一步對接。 ...
  • 構造函數和析構函數 構造函數是類的入口函數 析構函數是類的銷毀函數 1、構造函數 a、構造函數預設是public類型的,如果定義private則定義外部不能進行對象的創建,所以只能是公有函數 b、構造函數是入口函數,所以可以進行參數的初始化,可以對部分或全部的函數進行初始化操作 c、構造函數是可以有 ...
  • 驗證以及國際化 1.概述 (1)概述 對於輸入的數據(比如表單數據),進行必要的驗證,並給出相應的提示信息 對於驗證表單數據,SpringMVC 提供了很多使用的註解,這些註解由 JSR 303驗證框架提供。 (2)JSR 303 驗證框架 JSR 303 是 Java 為 Bean 數據合法性校驗 ...
  • 數據格式化 1.基本介紹 說明:在我們提交數據(比如表單時),SpringMVC 是怎樣對提交的數據進行轉換和處理的 基本數據類型可以和字元串之間自動進行轉換,比如:SpringMVC 上下文中內建了很多轉換器,可以完成大多數 java 類型的轉換工作。[相互轉換,這裡只列出部分] Conversi ...
  • 1.什麼是Golang Go(又稱Golang)是Google開發的一種靜態強類型、編譯型、併發型,並具有垃圾回收功能的編程語言。Go支持面向對象,而且具有真正的閉包(closures)和反射 (reflection)等功能。 2.谷歌為什麼要創造Go語言 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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...