NLB網路負載均衡管理器詳解

来源:http://www.cnblogs.com/knowledgesea/archive/2016/01/25/5157565.html
-Advertisement-
Play Games

序言在上一篇配置iis負載均衡中我們使用啦微軟的ARR,我在那篇文章也中提到了網站的高可用性,但是ARR只能做請求入口的消息分發服務,這樣如果我們的消息分發伺服器給down掉啦,那麼做再多的應用服務集群也都枉然。這篇文章我主要針對解決這一問題來做分析,引入NLB,相對於ARR來說,ARR算是應用級別...


序言

在上一篇配置iis負載均衡中我們使用啦微軟的ARR,我在那篇文章也中提到了網站的高可用性,但是ARR只能做請求入口的消息分發服務,這樣如果我們的消息分發伺服器給down掉啦,那麼做再多的應用服務集群也都枉然。

這篇文章我主要針對解決這一問題來做分析,引入NLB,相對於ARR來說,ARR算是應用級別的負載均衡方案,而NLB則是伺服器級別的負載均衡方案。

如果微軟的這兩款方案我們結合起來使用,那便是微軟高可用網站方案的天作之合啦。

Application Request Route與NLB高可用方案的演進

先說Application Request Route,他的具體實施方案,我已在我以前的文章中有描述,大家可以瞭解下,這裡我配圖做個簡介。

ARR可以檢測到你的iis應用是否可用,並對用戶的請求實施負載均衡方案,根據我們配置的負載均衡演算法,把用戶的請求分發到應用伺服器中。

但是,如果我們的ARR伺服器down掉之後,我們的整個應用程式就無法使用,達不到24*7用不宕機的高可用要求。

下麵配圖為NLB的網路負載平衡方案

NLB可以最多可以配置32台伺服器,這32台伺服器通過擁有自己的獨立ip之外,還共有一個虛擬IP,用戶訪問虛擬ip,nlb集群根據配置的負載演算法來確定把用戶的請求分發給那台應用伺服器,如果一臺NLB伺服器down掉,則不會影響消息的分發可達到7*24小時不down機的高可用方案。

但是,NLB不能檢測應用你的iis網站是否down掉,只能檢測伺服器是否down掉,這樣一來,如果你的iis網站已經停止啦,nlb還給分發用戶請求,那樣麻煩可就來啦。

那麼我們使用微軟的技術怎麼樣做到網站的高可用呢?對,就是NLB+Application Request Route .

用戶請求虛擬ip,接入nlb,nlb檢測一臺可用的伺服器,吧請求發給arr,arr在檢測可用的網站把用戶請求給處理掉。叼!!叼!!叼!!!!

NLB的安裝配置

打開windows伺服器,進入伺服器管理界面選擇功能,然後添加功能。

安裝過之後,打開網路負載平衡器 

新建集群,首先你在你區域網中,找一個沒有使用過的ip作為你集群的虛擬ip。

設置優先順序,優先順序數字越小,則代表越高。

添加集群ip也就是你事先檢查過區域網中不存在的一個ip地址,他就是圖中的虛擬ip。

設置需要集群負載的埠然後設置協議,分發形式。

然後再添加一臺伺服器到集群中。

這樣就成功啦。就是如此簡單。

那麼回過頭來我們來看下篩選模式的相關性。

無:加入A,B兩台伺服器,請求分發是這樣的:ABABABABABAB.....

單一:加入A,B兩台伺服器,請求分發是這樣的:AAAAAAAAAAAAAAAAA.....或者BBBBBBBBBBB....

網路:根據IP的Class C屏蔽來決定交由哪一部伺服器來處理,也就是一部伺服器只會處理來自某些網段C的請求。這種方式可確保使用多重Proxy的客戶端能導向到相同的伺服器。 

單一主機:優先順序別最高的一臺可用伺服器處理說有的用戶請求。

禁用此埠範圍:配置的埠範圍不做轉發,剩餘的才做。

展示下效果

53伺服器,訪問虛擬ip176,獲取到121伺服器的內容。

模擬100個用戶,發送1000個請求虛擬集群ip,黃色訪問的是121伺服器,白色是122伺服器,關聯性為無。

這篇文章就到這裡,其他的測試結果不一一展示,自己坐下吧,體會更深刻點。

總結

如果你在開發過程中使用啦這些技術,或者你要使用遇到啦什麼問題,歡迎加入左上角的群,我們一起討論學習。


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

-Advertisement-
Play Games
更多相關文章
  • stringstream ss;//一次創建多次使用,需要進行clear()操作清除流狀態標記int i=0;while (i>str;//執行後,流狀態標誌位可能會被置1,需要清除,否則影響後續操作 ss.clear();//不會出現重覆現象 cout<<str<<endl; ...
  • 題目:Automated Telephone Exchangepoj URL:http://poj.org/problem?id=4011原題如下圖:題意:就是一個三位數減去兩個小於或等於99的數的差為0,滿足這個條件的數的個數。只要用標準輸入輸出就可以了。下麵是我Accepted的代碼: 1 #i...
  • /*首先~命名空間的存在是為瞭解決 引用不同類中命名衝突問題的*//*1.定義命名空間*/ namespace My; class A{}; namespace Your; class A{}; /*2.在同一個項目中引用命名空間*/ namespace My; class A{};...
  • 利用Python語言實現Grib數據可視化主要依靠三個庫——pygrib、numpy和matplotlib。pygrib是歐洲中期天氣預報中心(ECMWF)的GRIG API C庫的Python介面,通過這個庫可以將Grib數據讀取出來;numpy是Python的一種開源的數值計算擴展,這種工具可用...
  • 上述if語句的等值判斷,可以用switch來代替。註意每個case後面一般要添加break,表示當前這個case執行完了;防止出現case穿透,即繼續執行case,直到遇到break才跳出。下麵例子反過來利用了case穿透現象。【例子】JDK7.0新特性:增強switch在JDK7之前,switch...
  • #!/bin/env python # -*- coding: UTF-8 -*- # 必須以root許可權運行 import socket import sys import timeimport random from struct import * # 計算校驗和 def ...
  • 回到目錄dynamic這個動態類型早在.net3.5時就已經出現了,當時是伴隨的Linq一起讓我們認識的,但在使用時總覺得有點彆扭,因為它是internal的,所以不能跨程式集使用,這對於分層開發的我們來說顯然是不能接受的,所以把dynamic了冷落了很久,應該說是5年吧,哈哈,這幾天在睡覺時,突然...
  • 值對象(value object)===================== 什麼是值對象 維基百科的定義 In computer science, a value object is a small object that represents a simple entity whose equ....
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...