負載均衡知識

来源:https://www.cnblogs.com/xiexin2015/archive/2018/05/19/9062083.html
-Advertisement-
Play Games

一提到負載均衡,相信很多同學都直接會想到nginx反向代理,因為我們平時比較熟悉的就是用nginx做web服務的負載均衡。其實nginx只是負載均衡里的一部分,在web應用中的每個層級其實都涉及到負載均衡。 那麼何為負載均衡?這個概念其實也同樣很重要,很多同學又說了,負載均衡還不簡單,就是在分散式系 ...


 

  一提到負載均衡,相信很多同學都直接會想到nginx反向代理,因為我們平時比較熟悉的就是用nginx做web服務的負載均衡。其實nginx只是負載均衡里的一部分,在web應用中的每個層級其實都涉及到負載均衡。

  那麼何為負載均衡?這個概念其實也同樣很重要,很多同學又說了,負載均衡還不簡單,就是在分散式系統中,將客戶端的請求均勻的分配到服務端(或者說將上游的請求,均衡的分配到下游的多個操作單元中),其實這隻回答了一半。請求的均衡是一方面,另一方面,數據也是要均衡的分佈在操作單元中的。

  因此,負載均衡就是將請求/數據【均勻】分攤到多個操作單元上執行。

 

  常見負載均衡方案

  梳理下web應用的基本架構:

  

  正常的web分散式項目的基本架構層級就是這樣(多台機器的集群我省略沒畫),分為客戶端層、反向代理nginx層、站點層、服務層、數據層

  【客戶端層->反向代理層】的負載均衡

  【客戶端層】到【反向代理層】的負載均衡,是通過“DNS輪詢”實現的:DNS-server對於一個功能變數名稱配置了多個解析ip,每次DNS解析請求來訪問DNS-server,會輪詢返回這些ip,保證每個ip的解析概率是相同的。這些ip就是nginx的外網ip,以做到每台nginx的請求分配也是均衡的。

 

  【反向代理層->站點層】的負載均衡

  【反向代理層】到【站點層】的負載均衡,是通過“nginx”實現的。通過修改nginx.conf,可以實現多種負載均衡策略:比如輪詢,最少連接路由,ip 哈希等等。

 

  【站點層->服務層】的負載均衡

  【站點層】到【服務層】的負載均衡,是通過“服務連接池”實現的。

 

  【數據層】的負載均衡

  在數據量很大的情況下,由於數據層(db,cache)涉及數據的水平切分,所以數據層的負載均衡更為複雜一些,它分為“數據的均衡”,與“請求的均衡”。

  數據的均衡是指:水平切分後的每個服務(db,cache),數據量是差不多的。

  請求的均衡是指:水平切分後的每個服務(db,cache),請求量是差不多的。

  常見的水平切分方式有這麼幾種:

  一、按照range水平切分:

  每一個數據服務,存儲一定範圍的數據,比如 db1服務,存儲uid範圍1-1kw; db2服務,存儲uid範圍1kw-2kw。

  這個方案的好處是:

  (1)規則簡單,service只需判斷一下uid範圍就能路由到對應的存儲服務

  (2)數據均衡性較好

  (3)比較容易擴展,可以隨時加一個uid[2kw,3kw]的數據服務

  不足是:

  (1)請求的負載不一定均衡,一般來說,新註冊的用戶會比老用戶更活躍,大range的服務請求壓力會更大。

  

  二、按照id哈希水平切分

  每一個數據服務,存儲某個key值hash後的部分數據,比如 db1服務,存儲偶數uid數據; db2服務,存儲奇數uid數據。

  這個方案的好處是:

  (1)規則簡單,service只需對uid進行hash能路由到對應的存儲服務

  (2)數據均衡性較好

  (3)請求均勻性較好

  不足是:

  (1)不容易擴展,擴展一個數據服務,hash方法改變時候,可能需要進行數據遷移。

 

  大伙兒有沒有發現,在分散式系統的架構設計上, 擴展性也是要經常考慮的因素哦!


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

-Advertisement-
Play Games
更多相關文章
  • 一、todolist功能開發 <div id="root"> <div> <input type="text" v-model="inputValue"> <button @click="handleSubmit">提交</button> </div> <ul> <li v-for="(item, ...
  • 今天終於能更新博文了……(確實有些不應該,5月份到現在就沒認認真真寫過幾行代碼) 今天算是正式在學Vue.js了,前期想必大家也能看得出來,我為那個即時通訊系統寫的代碼註釋,基本上都是自己在胡亂猜測的,很隨意很隨性的在寫註釋(可能都完全不正確…) 今天簡單的抄寫了兩個官網上的例子,花了半個小時左右的 ...
  • 前言 我的目標是寫一個非常詳細的關於diff的乾貨,所以本文有點長。也會用到大量的圖片以及代碼舉例,目的讓看這篇文章的朋友一定弄明白diff的邊邊角角。 先來瞭解幾個點... 1. 當數據發生變化時,vue是怎麼更新節點的? 要知道渲染真實DOM的開銷是很大的,比如有時候我們修改了某個數據,如果直接 ...
  • 深入css佈局(1)—— 盒模型 & 元素分類 “ 在css知識體系中,除了css選擇器,樣式屬性等基礎知識外,css佈局相關的知識才是css比較核心和重要的點。今天我們來深入學習一下css佈局相關的知識。” 首先來列下大綱 盒模型 IE盒模型 W3C盒模型 box-sizing 元素的分類 塊級元 ...
  • 談談對事件的理解: 從前有一家人,我們稱為window家。window他其中有一個兒子叫事件。 事件 事件他有很多好基友,每次發生什麼事情都會找到事件,叫他幫忙查看一下那些細節出現了問題。可是事件這個小子有時候遇到同一類型的事情會忘記前面那個小伙伴的問題,只記得最後的那個問題。但有時荷爾蒙分泌過多的 ...
  • console.log('請輸入三個數:'); let num1 = readline.question() - 0; let num2 = readline.question() - 0; let num3 = readline.question() - 0; let num4; if (num1 ...
  • 最近做個一個功能需要用到自動補全,然後在網上找了很久,踩了各種的坑 最後用typeahead.js這個插件,經過自己的測試完美實現 使用方法:在頁面中引入jquery、jquery.typeahead.min.js和jquery.typeahead.min.css文件。 html部分代碼: jque ...
  • 案例 我們所熟悉的jbdc是一種用於執行SQL語句的Java API,可以為多種關係資料庫提供統一訪問,提供了一種基準,據此可以構建更高級的工具和介面。 如上圖所示,任意的一個資料庫廠商只要去實現jdbc的介面,就可以輕鬆的對接jbdc從而為應用開發人員所服務。 SPI 上面的jdbc的設計理念叫S ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...