系統設計:關於高可用系統的一些技術方案

来源:https://www.cnblogs.com/gemsnow/archive/2019/08/21/11388613.html
-Advertisement-
Play Games

系統設計:關於高可用系統的一些技術方案 可靠的系統是業務穩定、快速發展的基石。那麼,如何做到系統高可靠、高可用呢?下麵從技術方面介紹幾種提高系統可靠性、可用性的方法。 擴展 擴展是最常見的提升系統可靠性的方法,系統的擴展可以避免單點故障,即一個節點出現了問題造成整個系統無法正常工作。換一個角度講,一 ...


系統設計:關於高可用系統的一些技術方案 可靠的系統是業務穩定、快速發展的基石。那麼,如何做到系統高可靠、高可用呢?下麵從技術方面介紹幾種提高系統可靠性、可用性的方法。   擴展 擴展是最常見的提升系統可靠性的方法,系統的擴展可以避免單點故障,即一個節點出現了問題造成整個系統無法正常工作。換一個角度講,一個容易擴展的系統,能夠通過擴展來成倍的提升系統能力,輕鬆應對系統訪問量的提升。   一般地,擴展可以分為垂直擴展和水平擴展:
  1. 垂直擴展:是在同一邏輯單元里添加資源從而滿足系統處理能力上升的需求。比如,當機器記憶體不夠時,我們可以幫機器增加記憶體,或者數據存不下時,我們為機器掛載新的磁碟。
  • 垂直擴展能夠提升系統處理能力,但不能解決單點故障問題。
  • 優點:擴展簡單。
  • 缺點:擴展能力有限。
  1. 水平擴展:通過增加一個或多個邏輯單元,並使得它們像整體一樣的工作。
  • 水平擴展,通過冗餘部署解決了單點故障,同時又提升了系統處理能力。
  • 優點:擴展能力強。
  • 缺點:增加系統複雜度,維護成本高,系統需要是無狀態的、可分散式的。
可擴展性繫數 scalability factor 通常用來衡量一個系統的擴展能力,當增加 1 單元的資源時,系統處理能力只增加了 0.95 單元,那麼可擴展性繫數就是 95%。當系統在持續的擴展中,可擴展繫數始終保持不變,我們就稱這種擴展是線性可擴展。   在實際應用中,水平擴展最常見:
  1. 通常我們在部署應用伺服器的時候,都會部署多台,然後使用 nginx 來做負載均衡,nginx 使用心跳機制來檢測伺服器的正常與否,無響應的服務就從集群中剔除。這樣的集群中每台伺服器的角色是相同的,同時提供一樣的服務。
  2. 在資料庫的部署中,為了防止單點故障,一般會使用一主多從,通常寫操作只發生在主庫。不同資料庫之間角色不同。當主機宕機時,一臺從庫可以自動切換為主機提供服務。
隔離 隔離,是對什麼進行隔離呢?是對系統、業務所占有的資源進行隔離,限制某個業務對資源的占用數量,避免一個業務占用整個系統資源,對其他業務造成影響。   隔離級別按粒度從小到大,可以分為線程池隔離、進程隔離、模塊隔離、應用隔離、機房隔離。在資料庫的使用中,還經常用到讀寫分離。
  1. 線程池隔離:不同的業務使用不同的線程池,避免低優先順序的任務阻塞高優先順序的任務。或者高優先順序的任務過多,導致低優先順序任務永遠不會執行。
  2. 進程隔離:Linux 中有用於進程資源隔離的 Linux CGroup,通過物理限制的方式為進程間資源控制提供了簡單的實現方式,為 Linux Container 技術、虛擬化技術的發展奠定了技術基礎。在工作中的實際應用,可以看看這篇文章:日誌壓縮資源消耗優化: Linux CGroup 的使用
  3. 模塊隔離、應用隔離:很多線上故障的發生源於代碼修改後,測試不到位導致。按照代碼或業務的易變程度來劃分模塊或應用,把變化較少的劃分到一個模塊或應用中,變化較多的劃分到另一個模塊或應用中。減少代碼修改影響的範圍,也就減少了測試的工作量,減少了故障出現的概率。
  4. 機房隔離:主要是為了避免單個機房網路問題或斷電吧。
  5. 讀寫分離:一方面,將對實時性要求不高的讀操作,放到 DB 從庫上執行,有利於減輕 DB 主庫的壓力。另一方面,將一些耗時離線業務 sql 放到 DB 從庫上執行,能夠減少慢 sql 對 DB 主庫的影響,保證線上業務的穩定可靠。
解耦 在軟體工程中,對象之間的耦合度就是對象之間的依賴性。對象之間的耦合越高,維護成本越高,因此對象的設計應使模塊之間的耦合度儘量小。在軟體架構設計中,模塊之間的解耦或者說松耦合有兩種,假設有兩個模塊A、B,A依賴B:
  1. 第一種是,模塊A和模塊B只通過介面交互,只要介面設計不變,那麼模塊B內部細節的變化不影響模塊A對模塊B服務能力的消費。
  • 面向介面設計下真正實現了將介面契約的定義和介面的實現徹底分離,實現變化不影響到介面契約,自然不影響到基於介面的交互。
  • 模塊A和B之間的松耦合,主要通過合理的模塊劃分、介面設計來完成。如果出現迴圈依賴,可以將模塊A、B共同依賴的部分移除到另一個模塊C中,將A、B之間的相互依賴,轉換為A、B同時對C的依賴。
  1. 第二種是,將同步調用轉換成非同步消息交互。
  • 比如在買機票系統中,機票支付完成後需要通知出票系統出票、代金券系統發券。如果使用同步調用,那麼出票系統、代金券系統宕機是會影響到機票支付系統,如果另一個系統比如專車系統也想要在機票支付完成後向用戶推薦專車服務,那麼同步調用模式下機票支付系統就需要為此而改動,容易影響核心支付業務的可靠性。
  • 如果我們將同步調用替換成非同步消息,機票支付系統發送機票支付成功的消息到消息中間件,出票系統、代金券系統從消息中間件訂閱消息。這樣一來,出票系統、代金券系統的宕機也就不會對機票支付系統造成任何影響了。專車系統想要知道機票支付完成這一事件,也只需要從消息中間件訂閱消息即可,機票支付系統完全不需要做任何改動。
  • 非同步消息解耦,適合那些信息流單向流動(類似發佈-訂閱這樣的),實時性要求不高的系統。常見的開源消息隊列框架有:Kafka、RabbitMQ、RocketMQ。
限流 為什麼要做限流呢?舉一個生活中的例子,大家早上上班都要擠地鐵吧,地鐵站在早高峰的時候經常要限制客流,為什麼呢?有人會覺得這是人為添堵。真是這樣嗎?如果不執行客流控制,大家想想會是什麼場景呢?站臺到處都擠滿了乘客,就算你使出洪荒之力也不一定能順利上車,且非常容易引發肢体碰撞,造成衝突。有了客流控制之後,地鐵站才能變得秩序井然,大家才能安全上地鐵。   一個系統的處理能力是有上限的,當服務請求量超過處理能力,通常會引起排隊,造成響應時間迅速提升。如果對服務占用的資源量沒有約束,還可能因為系統資源占用過多而宕機。因此,為了保證系統在遭遇突發流量時,能夠正常運行,需要為你的服務加上限流。 常見的限流演算法有:漏桶、令牌桶、滑動視窗計數。   分類 按照計數範圍,可以分為:單機限流、全局限流。單機限流,一般是為了應對突發流量,而全局限流,通常是為了給有限資源進行流量配額。 按照計數周期,可以分為:QPS、併發(連接數)。 按照閾值設定方式的不同,可以分為:固定閾值、動態閾值。   漏桶演算法 下麵這張圖,是漏桶的示意圖。漏桶演算法思路很簡單,水(請求)先進入到漏桶里,漏桶以一定的速度出水,當水流入速度過大時,會直接溢出,可以看出漏桶演算法能強行限制數據的傳輸速率。漏桶演算法(Leaky Bucket)是網路世界中流量整形(Traffic Shaping)或速率限制(Rate Limiting)時經常使用的一種演算法,它的主要目的是控制數據註入到網路的速率,平滑網路上的突發流量。                                        漏桶演算法原理 漏桶演算法可以使用 Redis 隊列來實現,生產者發送消息前先檢查隊列長度是否超過閾值,超過閾值則丟棄消息,否則發送消息到 Redis 隊列中;消費者以固定速率從 Redis 隊列中取消息。Redis 隊列在這裡起到了一個緩衝池的作用,起到削峰填谷、流量整形的作用。   令牌桶演算法 對於很多應用場景來說,除了要求能夠限制數據的平均傳輸速率外,還要求允許某種程度的突發傳輸。這時候漏桶演算法可能就不合適了,令牌桶演算法更為適合。令牌桶演算法的原理是系統會以一個恆定的速度往桶里放入令牌,而如果請求需要被處理,則需要先從桶里獲取一個令牌,當桶里沒有令牌可取時,則拒絕服務。桶里能夠存放令牌的最高數量,就是允許的突發傳輸量。
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JQuery Ztree 樹插件配置與應用小結 by:授客 QQ:1033553122 測試環境 Win7 jquery-3.2.1.min.js 下載地址: https://gitee.com/ishouke/front_end_plugin/blob/master/jquery-3.2.1.mi ...
  • 摘要: React Hooks原理解析。 原文: "快速瞭解 React Hooks 原理" 譯者:前端小智 我們大部分 React 類組件可以保存狀態,而函數組件不能? 並且類組件具有生命周期,而函數組件卻不能? React 早期版本,類組件可以通過繼承 來優化一些不必要的渲染,相對於函數組件,R ...
  • 精心整理了之前的css學習筆記,僅供學習參考使用,禁止商業用途 [TOC] CSS 簡介 1.CSS 簡介 CSS 概述 CSS 指層疊樣式表 (Cascading Style Sheets) 樣式定義如何顯示 HTML 元素 樣式通常存儲在樣式表中 把樣式添加到 HTML 4.0 中,是為瞭解決內 ...
  • 函數 函數:即方法 函數就是一段預先設置的功能代碼塊,可以反覆調用,根據輸入參數的不同,返回不同的值。 為什麼使用函數: 1.方便調用 2.代碼重用,利於維護 3.便於修改,便於重構 4.簡化邏輯,利於編程 1、聲明函數 聲明函數 Function Declaration 的三種方法 1)funct ...
  • 在HTML頭部標簽加上如下代碼即可 <meta name="referrer" content="no-referrer"/> ...
  • 10:14:11獨立開發者在開發移動端產品時,為了更高效,通常會使用Web技術來開發移動端項目,可以同時適配Android、iOS、H5,稍加改動還可適配微信小程式。 在使用Vue.js開發移動端頁面的時候,預設的組件轉場效果過於生硬,根本就沒有動畫效果。於是我用Vue提供的組件過渡功能,寫了個仿微 ...
  • 官網:www.fhadmin.org 特別註意: Springboot 工作流 前後分離 + 跨域 版本 (許可權控制到菜單和按鈕) 後臺框架:springboot2.1.2+ activiti6.0.0+ mybaits+maven+介面 前端頁面:html +vue.js 形式 jquery aj ...
  • 在上一篇文章中,說了什麼是類。而在最後留下了一個問題:“湯姆和瑪麗把一隻大象往一個冰箱裡面裝”。這句話跟類又有什麼關係? 通過對比最開始的句子:“一隻動物被兩個人往一個家電裡面裝”。可以看到,現在這兩個不同的句子都描述著同樣的一個場景,意思都差不多,但這個場景中不同句子描述的事物不同。 那在這兩個句 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...