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

来源:https://www.cnblogs.com/wing011203/archive/2023/03/03/17174280.html
-Advertisement-
Play Games

這篇文章主要討論分散式系統中的故障恢復和常用的故障檢測方法,包括固定心跳檢測和根據歷史心跳信息預測故障檢測方法。 ...


故障恢復

我們之前講過故障隔離,它的目的是對故障組件進行隔離,以避免影響系統中的其他組件,儘可能保證分散式系統的可用性。

但是之後故障隔離還不夠,我們需要考慮進行故障恢復。

什麼是分散式故障?

分散式系統中的故障,可以分為兩類:

  1. 物理故障,例如硬碟損壞、斷電斷網等。
  2. 軟體故障,例如系統中存在的bug導致系統崩潰、負載過高等。

我們可以對故障進行分類討論,包括:

  • 節點故障,可以分為硬體故障和軟體故障兩種,主要表現是機器無法為用戶提供服務。
  • 網路故障,節點間無法通信,從而影響分散式應用正常提供服務。

什麼是故障檢測和恢復?

故障檢測,是指通過一定的方式識別或者發現故障。

在分散式系統中,檢測硬體故障通常會比較複雜,因此是通過查看軟體層的表現結果進行故障檢測。

故障檢測,通過一定方式來識別或者發現故障。

在分散式系統中,檢測硬體故障通常比較麻煩因此會通過軟體層的表現結果進行故障檢測。

故障恢復,是指修複分散式系統中出現的故障,使系統恢復正常。

在分散式系統中,常見的故障檢測方法就是心跳機制,我們可以把它分為兩類:

  1. 固定心跳檢測策略
  2. 根據歷史心跳信息預測故障檢測策略

故障恢復策略

對於單點故障問題,往往採取主備策略,即當主節點故障後,從備節點中選出一個作為新的主節點。以繼續提供服務。

對於網路故障問題的解決方案,簡單來說就是C、A、P選擇的問題。

當分散式系統中出現網路故障時,對於高可用性要求嚴格的系統,會要求必須及時響應用戶的場景,就需要保AP放棄C的策略,對於數據一致性有嚴格要求的系統,就需要保CP放棄A的策略。

網路恢復問題也可以看做是數據恢復問題,即網路故障恢復之後節點之間數據進行同步的問題。

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

-Advertisement-
Play Games
更多相關文章
  • 前言 其實在 2019 年上半年,微信就發佈了基於小程式頁面的搜索,只是很多小伙伴並不知道,所以在這分享一下微信小程式搜索優化指南(SEO)。 為了更好地發現及理解小程式的頁面,強烈建議各位小伙伴花一些寶貴的時間認真閱讀本文。 小程式爬蟲 爬蟲訪問小程式內頁面時,會攜帶特定的 user-agent ...
  • 前端要不要學習設計模式 始終認為每個行業都有自己的特點,各自的專業性。一個開發工程師如果不知道電腦是哪些基本硬體組成,那麼我們大概率都會認為這個人非常不專業。那麼前端要不要學設計模式呢?設計模式跟前端有多大關係呢? 前端工程師首先是一個工程師,既然是一個軟體工程師,那麼類似設計模式、數據結構、網路相 ...
  • map、forEach、filter這三者都可以遍曆數組,他們之間有什麼區別呢? map():方法定義在JavaScript的Array中,它返回一個新的數組,數組中的元素為原始數組調用函數處理後的值值得註意的是: 1、map()函數不會對空數組進行檢測; 2、map()函數不會改變原始數組,它形成 ...
  • <!DOCTYPE html> <html> <head> <title>Get Video Frame Example</title> </head> <body> <div id="result"></div> <script> // 獲取視頻第一幀的函數 function getVideoFi ...
  • 今天早上打開電腦,更新了日常工作的github倉庫,然後就是習慣性地執行了"npm install",發現報了下麵這個錯誤: Error: error:0308010C:digital envelope routines::unsupported 順便看了一下錯誤堆棧,發現是一個Node的內核文件拋 ...
  • 在許久之前,曾經寫過這樣一篇文章 -- 不定寬溢出文本適配滾動。我們實現了這樣一種效果: 文本內容不超過容器寬度,正常展示 文本內容超過容器的情況,內容可以進行跑馬燈來回滾動展示 像是這樣: 但是,之前的方案,有一個很明顯的缺點,如果我們事先知道了容器的寬度,那麼沒問題,但是如果沒法確定容器的寬度, ...
  • 客戶端和伺服器 客戶端與伺服器的通信 互聯網:錯綜複雜的網路,比如每個快遞車走的路. TCP/IP:定義數據如何傳輸的通信協議,比如快遞的包裝,發貨規則. DNS:功能變數名稱系統伺服器,輸入一個網址時,找到網頁的伺服器,才能發送 HTTP 請求到正確的地方。(功能變數名稱->IP),比如發貨地址. HTTP:超文 ...
  • 一起來看看大道至簡的一些基本設計思想,首先我們來看一下什麼是封裝。 封裝:也叫做信息隱藏,或者數據訪問保護。放到程式上來講,就是隱藏類的屬性,還有實現細節,僅對外公開一些介面。那麼外部,就只能通過這個類暴露的這些訪問介面,按照這個類提供的方式來訪問類的內部信息或者數據。這樣子的一種情況就叫做封裝。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...