小編為大家分享一篇windows第四層負載均衡_基於NLB負載均衡詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
TCP/IP協議族,第七層是應用層,第四層是傳輸層。第四層負載均衡主要透過IP進行轉化。
一些優秀的第四層負載均衡軟體,速度可以接近硬體負載均衡的效率。當然,論速度還是人家硬體的快一點點,畢竟人家那價格擺在那裡,一臺F5,十幾萬,幾十萬,上百萬不等。
第四層重與第七層相比:優秀就是速度快,能感知叢集伺服器的狀態。缺點就是不能感知應用層軟體的狀態,比如IIS站點掛掉,但是如果伺服器沒有掛掉,轉化流量用繼續流入該伺服器。
現在很多的第四層負載均衡軟體,我是說LINUNX伺服器下。如果你使用了Windows,我還是建議大夥吃人家的全家桶吧。效能肯定不能最大化。但是論穩定性,維護性還是全家桶好使,省心,省力。
如果,你購買了微軟的正版系統,你還可以一個電話,讓人家工程師幫你解決問題。前提是,你得用的是全家桶。
常見的第四層負載均衡軟體:LVS,NLB,還有其它,一時想不起來了,懶得查了。
下面講講怎麼安裝NLB,當然我使用的是帶GUI的作業系統,一般情況LINUX的是不裝GUI的,但是window的黑框我還沒有習慣,還不會用,就先用帶GUI的吧
安裝NBL功能
首先點服務管理器。
一直點“下一步”,直到勾上這個
安裝成功。
每一臺參與NLB的伺服器,都需要安裝。這跟ARR不一樣,ARR只需要在轉發伺服器上面安裝即可。
這裡作為演示例子,就給三臺伺服器裝上NLB吧
分別是:
192.168.99.8
192.168.99.10
192.168.99.11
工作原理
所有請求會分發到每一臺NLB伺服器,然後NLB伺服器根據演算法處理自己那一份請求。
那麼所有請求是怎麼分發給每一臺伺服器暱,因為他們有一個公共的IP。也是就說,每臺伺服器有兩個IP。
是的,每電腦可以有多個IP地址。
高階選項中,可以手動新增多個IP地址。
搭建叢集
開啟網路負載平衡管理器,新建叢集
一直點“下一步”,直到完成。
192.168.99.10,192.168.99.20的伺服器分別按下步驟操作。
一直點“下一步”,直到完成。
叢集部署完畢。
我們檢視IP,你發現,多一個公共IP,192.168.99.20 這個就是群集的IP。
搭建好之後,我們就走一波試試,試跑成功之後,再來講講一些細節配置吧
首先IIS要做一些設定,因為我們將使用公共IP進行訪問,就是192.168.99.20
訪問http://192.168.99.20/api/home/GetUserChat
成功返回。
壓力測試
老規則,現在用VS2017進行壓力測試,完事之後,講點細節配置這事就算完成啦。
測試成功,但是問題也是相當明顯
第一,資料的確廣發給每個伺服器,我們可以看,接收的資料大小都是一樣的5.4Mbps
第二,傳送的資料大小卻完全不一樣,這說明處理不一樣。我們可以明顯看到,192.168.99.10這臺伺服器,承擔了大部分的工作。CPU上升到94%,傳送資料包也達到1.5Mbps。
細節配置
很明顯叢集配置不合適。下面我們來講講細節細置
叢集操作模式:
單播:所有節點伺服器的MAC都會被改成叢集MAC,傳送資料的時候源MAC將變成叢集MAC。缺點:交換機的MAC表無法繫結該MAC歸屬那個埠,所有資料包都進行廣播,造流量負擔。所有節點伺服器具有相同MAC,無法相通訊。也就是說,叢集節點,具有相同的IP和相同MAC地址。
多播:不會修改節點伺服器的MAC,而是為專節點伺服器新增多一個叢集MAC,節點之間可以透過專用IP進行相互通訊。
單網路卡多播,雙網路卡單播。雙網路卡可以設定內網網路卡成為專用IP,解決單播節點不能相互通訊問題。
叢集埠規則:
篩選模式:
多臺主機:所有資料由多臺伺服器處理。
單個主機:所有資料由一臺伺服器處理,根據優先順序選出伺服器。
禁用此埠範圍:禁止這個埠的資料,進行處理。
多臺主機模式下,相關性:
無:由負載均衡器根根演算法處理,基本上請求平均分配。
單一:同一個客戶端的請求,歸屬原來的處理的伺服器。
網路:根據IP的C類地址範圍來決定分配。也就是同一網段的請求,會分配某一伺服器上。
優先順序:叢集中所有轉發根據埠規則進行處理,如果不符合埠規則,將統一由優先順序最小的伺服器進行處理。
為什麼我們開始時候,192.168.99.10承受大量的工作,因為埠規則沒有設定好,我們現在重新設定一下埠規則,再來測試一下吧。
之前預設設定
重新設定之後的配置
好,我們重新跑一趟壓力
網路接受和傳送比較平等。
每個伺服器接受的請求數,大概相等。
每秒處理150個。與伺服器資料相吻合。
負載均衡基本達到與預期效果一致。
NLB叢集測試完畢。
以上這篇windows第四層負載均衡_基於NLB負載均衡詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,