LVS-NAT模式的配置詳解

来源:https://www.cnblogs.com/happenlee/archive/2018/03/14/8570197.html
-Advertisement-
Play Games

由於實驗室擬態存儲的項目需要通過NAT模式來映射NFS伺服器已實現負載均衡的目的,通過調研了多種負載均衡機制,筆者最終選擇了 LVS的NAT模式 來實現需求,接下來通過博客來記錄一下LVS NAT模式的配置流程。 1.LVS服務的簡介: LVS 是 Linux Virtual Server 的簡寫, ...


由於實驗室擬態存儲的項目需要通過NAT模式來映射NFS伺服器已實現負載均衡的目的,通過調研了多種負載均衡機制,筆者最終選擇了LVS的NAT模式來實現需求,接下來通過博客來記錄一下LVS-NAT模式的配置流程。

1.LVS服務的簡介:

LVSLinux Virtual Server的簡寫,意即Linux虛擬伺服器,是一個虛擬的伺服器集群系統,在1998年5月由章文嵩先生主導開發。LVS集群實現了IP負載均衡技術和基於內容請求分發技術。調度器通過將請求均衡地轉移到不同的伺服器上執行,且可以屏蔽掉後臺故障的伺服器,從而將一組伺服器構成一個高性能的、高可用的伺服器集群,而這樣的結構對客戶端來說是完全透明的,所以無需修改客戶端和伺服器端的程式。

LVS伺服器可以讓客戶端將LVS伺服器作為一個連接的單點,僅僅通過連接LVS伺服器便可以得到後端一整個伺服器集群的處理與存儲能力,這樣能夠大大提高系統的擴展性與可用性,同時也能夠提供服務的安全性,單一入侵一臺伺服器並不會破壞其他與該伺服器隔離的服務。

LVS的模式

LVS可以支持如下三種模式:

  • Virtual Server via Network Address Translation(VS/NAT)
    通過網路地址轉換,調度器重寫請求報文的目標地址,根據預設的調度演算法,將請求分派給後端的真實伺服器;真實伺服器的響應報文通過調度器時,報文的源地址被重寫,再返回給客戶,完成整個負載調度過程。

  • Virtual Server via IP Tunneling(VS/TUN)
    採用NAT技術時,由於請求和響應報文都必須經過調度器地址重寫,當客戶請求越來越多時,調度器的處理能力將成為瓶頸。為瞭解決這個問題,調度器把請求報 文通過IP隧道轉發至真實伺服器,而真實伺服器將響應直接返回給客戶,所以調度器只處理請求報文。由於一般網路服務應答比請求報文大許多,採用 VS/TUN技術後,集群系統的最大吞吐量可以提高10倍。

  • Virtual Server via Direct Routing(VS/DR)
    VS/DR通過改寫請求報文的MAC地址,將請求發送到真實伺服器,而真實伺服器將響應直接返回給客戶。同VS/TUN技術一樣,VS/DR技術可極大地 提高集群系統的伸縮性。這種方法沒有IP隧道的開銷,對集群中的真實伺服器也沒有必須支持IP隧道協議的要求,但是要求調度器與真實伺服器都有一塊網卡連 在同一物理網段上。

鑒於ip安全的需求,這裡我們需要分割LVS伺服器與後端負載集群的ip地址,並且對於負載均衡集群的數目沒有太大的需求,所以筆者選用了Virtual Server via Network Address Translation(VS/NAT) 模式。

2.系統環境:

如下圖所示,這是LVS-NAT模式下的系統結構圖:
LVS-NAT模式的結構圖

系統平臺:Ubuntu 16.04 LTS

Load Balancer: 雙網卡

  • 外網地址:219.223.199.164
  • 內網地址:192.168.1.30

Real Server:

  • 一共有五台機器,ip地址分別為192.168.1.21~25。這裡筆者由於需要掛載NFS伺服器並且串聯CephFS集群,所以本身Real Server上已經運行著NFS的服務端,關於NFS伺服器的搭建可以參考我之前的博文

3.Load Balancer伺服器的配置:

Load Balancer伺服器的配置相對來說較為複雜,我們按部就班的走下這個流程:

  • ipvsadm
    LVS依賴於ipvsadm來進行配置,所以我們首先先安裝ipvsadm:

    sudo apt-get install ipvsadm

  • NAT模式下的ip轉發
    之後我們需要配置NAT模式下的ip轉發,讓通過Load Balancer的ip包能夠轉發到真正提供服務的Real Server之上進行處理:

    echo 1 >> /proc/sys/net/ipv4/ip_forward //在ipv4環境下可以進行ip轉發
    sudo iptables -t nat -F //清除之前的iptable的規則
    sudo iptables -t nat -A POSTROUTING -s 192.168.1.0/24 -o ens160 -j MASQUERADE
    //這裡的網卡需要選擇外網ip,也就是219.223.199.164對應的ip地址

  • LVS-NAT模式的配置
    這裡我們採取全盤轉發的機制,也就是不指定埠的方式,這種用法可能相對比較少見,但由於NFS服務依賴與rpcbind選擇埠,所以提供的埠是隨機的,為了簡單起見,我們採取全盤轉發的模式。

    sudo ipvsadm -A -t 219.223.199.164 -s wrr -p 30 //轉發對應的ip,並且採取權重輪詢的策略
    sudo ipvsadm -a -t 219.223.199.164 -r 192.168.1.21 -m -w 1
    sudo ipvsadm -a -t 219.223.199.164 -r 192.168.1.22 -m -w 1
    sudo ipvsadm -a -t 219.223.199.164 -r 192.168.1.23 -m -w 1
    sudo ipvsadm -a -t 219.223.199.164 -r 192.168.1.24 -m -w 1
    sudo ipvsadm -a -t 219.223.199.164 -r 192.168.1.25 -m -w 1 //依次添加對應的Real Server伺服器

下圖是通過ipvsadm配置好的轉發機制:
ipvsadm的配置

4.Real Server伺服器的配置:

Real Server這裡需要配置路由,將預設的網關改為Load Balancer 伺服器的內網ip地址,來實現路由轉發的效果。(筆者這裡多提一句:這裡如果採用雙網卡機制很容易出現,TCP連接問題,也就是syn消息收不到ack響應,所以儘量將無關的網卡警用,以免路由配置的複雜。

route命令的配置

    sudo route add -net 0.0.0.0 gw 192.168.1.30

這個命令需要在每台Real Server之上執行,否則其他Real Server沒有辦法接受到轉發的ip數據包,會被Load Balance屏蔽,從而沒有辦法實現我們期待的負載均衡的結果。下圖所示的是Real Server伺服器路由轉發配置的結果:
Real Server的路由表

5.LVS-NAT模式的測試:

由於實現了LVS全盤的ip地址轉發,所以任何基於TCP的網路服務都可以通過Load Balancer轉發給後端的Real Server來提供對外的服務,由於筆者主要是測試NFS服務的,所以我們先在Real Server之上啟動對應的NFS服務:

為了使NFS伺服器能正常工作,需要啟動rpcbind和nfs-kernel-server兩個服務,並且rpcbind一定要先於nfs-kernel-server啟動。

  sudo service rpcbind start
  sudo service nfs-kernel-server start

之後我們便可以執行NFS客戶端的掛載工作了,過載工作很簡單,先建立一個掛載目錄,然後通過mount命令掛載Load Balancer的外網ip:

  sudo mkdir /mnt/ceph
  sudo mount -t nfs 219.223.199.164:/mnt/cephfs /mnt/ceph

之後客戶端對應的文件目錄便掛載上對應Real Server上的文件系統了。(這裡的NFS服務是筆者預先搭建好的,讀者可以自行搭建自己所需的網路服務。
如下圖所示,我們掛載了遠端219.223.199.164的NFS伺服器,而實際的服務是由後端的Real Server來提供的:
掛載了遠端的NFS伺服器

小結:梳理了一下在LVS-NAT模式之下的安裝與配置。RedHat系列的發行版也是大同小異。這裡調試一定需要有足夠的耐心和毅力,需要去細緻的排查,否則很容易出現問題。若有疏漏,望各位指點斧正。


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

-Advertisement-
Play Games
更多相關文章
  • “System.TimeoutException”類型的異常在 MongoDB.Driver.Core.dll 中發生,但未在用戶代碼中進行處理 操作MongoDB類庫版本: 連接字元串的相關變化: 沒有安全認證的URL:mongodb://127.0.0.1:27017 加上安全認證的URL:mo ...
  • 雖然有過三年的開發經歷,但是還是小菜一枚,在大鳥的指導下,開始專業化進入軟體這條道路。 首先大鳥推薦第一本書籍,就是《大話設計模式》。一邊做筆記一邊看書,書中以身邊的故事,引出6種設計原則&23種設計模式。 歷練使人成長,經驗迸發靈感。然而所有的靈感都應有其因,那就是萬變不離其宗的六大面向對象的設計 ...
  • 代碼: <Window x:Class="WpfApplication1.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.c ...
  • 這幾天學習分析聲音的波形數據,接收到的是十六進位的數據,需要將數據轉換成十進位再繪圖,這個過程涉及到字元串的分割,正好可以促進自己對C#相關知識的學習。說到分割字元串,我首先想到的是Split,但根據本例分割要求無法直接使用,需要進行一些處理。通過比較,我覺得常用於截取字元串的substring函數 ...
  • 1.登錄CentOS。 2.# dhclient 自動獲取IP地址 3.# ip addr 1).第一個地址127.0.0.1是迴環地址,網卡名叫做lo,Windows操作系統也有該地址,用來和自己通信。 2).第二個192.168.123.130就是剛剛自動獲取的IP地址。ens33就是網卡的名字 ...
  • 今天安裝mongodb後發現apache無法啟動 命令行 services.msc 打開服務 在服務里啟動Apache2a服務,報錯誤碼1 網上查有很多情況都報的1 可以通過命令行下 執行apache bin 下的 httpd.exe進一步瞭解 AH00548: NameVirtualHost ha ...
  • linux的安裝問題 預備: 我開始學習Linux使用的是《鳥哥的Linux私房菜 基礎學習篇》,在書中提到的安裝方法是光碟安裝。 問題是,我沒有光碟,這就很僵硬了。 通過網路的掃蕩,我選擇了一個非常簡單的方法——U盤安裝。 需要:1、UltraISO工具(製作啟動U盤)(https://www.l ...
  • 1.新建虛擬機==》典型==》稍後安裝操作系統==》選擇linux==>centos 64位 2.填寫虛擬機名字以及安裝位置。 3.磁碟容量採用預設即可。 4. 自定義硬體: 1) 記憶體:如果電腦記憶體小於等於4G,設為1G;否則設為2G 2)CD/DVD 先預設。 3)網路適配器:NAT 4)其他選 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...