複製鏈接
請複製以下鏈接發送給好友

LVS

(Linux虛擬服務器)

鎖定
LVSLinux Virtual Server的簡寫,意即Linux虛擬服務器,是一個虛擬的服務器集羣系統。本項目在1998年5月由章文嵩博士成立,是中國國內最早出現的自由軟件項目之一。
中文名
Linux虛擬服務器
外文名
LVS
類    屬
計算機軟件
創始人
章文嵩
全    稱
Linux Virtual Server
創立時間
1998年5月
軟件授權
自由軟件

LVS產品宗旨

使用集羣技術和Linux操作系統實現一個高性能、高可用的服務器.
很好的可伸縮性(Scalability)
很好的可靠性(Reliability)
很好的可管理性(Manageability)。 [1] 

LVS產品特點

可伸縮網絡服務的幾種結構,它們都需要一個前端的負載調度器(或者多個進行主從備份)。我們先分析實現虛擬網絡服務的主要技術,指出IP負載均衡技術是在負載調度器的實現技術中效率最高的。在已有的IP負載均衡技術中,主要有通過網絡地址轉換(Network Address Translation)將一組服務器構成一個高性能的、高可用的虛擬服務器,我們稱之為VS/NAT技術(Virtual Server via Network Address Translation)。在分析VS/NAT的缺點和網絡服務的非對稱性的基礎上,我們提出了通過IP隧道實現虛擬服務器的方法VS/TUN (Virtual Server via IP Tunneling),和通過直接路由實現虛擬服務器的方法VS/DR(Virtual Server via Direct Routing),它們可以極大地提高系統的伸縮性。VS/NAT、VS/TUN和VS/DR技術是LVS集羣中實現的三種IP負載均衡技術。

LVS技術

【1】技術簡介
LVS集羣採用IP負載均衡技術和基於內容請求分發技術。調度器具有很好的吞吐率,將請求均衡地轉移到不同的服務器上執行,且調度器自動屏蔽掉服務器的故障,從而將一組服務器構成一個高性能的、高可用的虛擬服務器。整個服務器集羣的結構對客户是透明的,而且無需修改客户端和服務器端的程序。為此,在設計時需要考慮系統的透明性、可伸縮性、高可用性和易管理性。
【2】集羣採用三層結構
一般來説,LVS集羣採用三層結構,其主要組成部分為:
A、負載調度器(load balancer),它是整個集羣對外面的前端機,負責將客户的請求發送到一組服務器上執行,而客户認為服務是來自一個IP地址(我們可稱之為虛擬IP地址)上的。
B、服務器池(server pool),是一組真正執行客户請求的服務器,執行的服務有WEB、MAIL、FTP和DNS等。
C、共享存儲(shared storage),它為服務器池提供一個共享的存儲區,這樣很容易使得服務器池擁有相同的內容,提供相同的服務。
【3】調度器
調度器是服務器集羣系統的唯一入口點(Single Entry Point),它可以採用IP負載均衡技術、基於內容請求分發技術或者兩者相結合。
在IP負載均衡技術中,需要服務器池擁有相同的內容提供相同的服務。當客户請求到達時,調度器只根據服務器負載情況和設定的調度算法從服務器池中選出一個服務器,將該請求轉發到選出的服務器,並記錄這個調度;當這個請求的其他報文到達,也會被轉發到前面選出的服務器。在基於內容請求分發技術中,服務器可以提供不同的服務,當客户請求到達時,調度器可根據請求的內容選擇服務器執行請求。因為所有的操作都是在Linux操作系統核心空間中完成的,它的調度開銷很小,所以它具有很高的吞吐率。服務器池的結點數目是可變的。當整個系統收到的負載超過所有結點的處理能力時,可以在服務器池中增加服務器來滿足不斷增長的請求負載。
對大多數網絡服務來説,請求間不存在很強的相關性,請求可以在不同的節點上並行執行,所以整個系統的性能基本上可以隨着服務器池的結點數目增加而線性增長。 共享存儲通常是數據庫、網絡文件系統或者分佈式文件系統。服務器結點需要動態更新的數據一般存儲在數據庫系統中,同時數據庫會保證併發訪問時數據的一致性。靜態的數據可以存儲在網絡文件系統(如NFS/CIFS)中,但網絡文件系統的伸縮能力有限,一般來説,NFS/CIFS服務器只能支持3~6個繁忙的服務器結點。對於規模較大的集羣系統,可以考慮用分佈式文件系統,如AFS、GFS、Coda和Intermezzo等。分佈式文件系統可為各服務器提供共享的存儲區,它們訪問分佈式文件系統就像訪問本地文件系統一樣,同時分佈式文件系統可提供良好的伸縮性和可用性。
【4】分佈式鎖管理器
此外,當不同服務器上的應用程序同時讀寫訪問分佈式文件系統上同一資源時,應用程序的訪問衝突需要消解才能使得資源處於一致狀態。這需要一個分佈式鎖管理器(Distributed Lock Manager),它可能是分佈式文件系統內部提供的,也可能是外部的。開發者在寫應用程序時,可以使用分佈式鎖管理器來保證應用程序在不同結點上併發訪問的一致性。
負載調度器、服務器池和共享存儲系統通過高速網絡相連接,如100Mbps交換網絡、Myrinet和Gigabit網絡等。使用高速的網絡,主要為避免當系統規模擴大時互聯網絡成為整個系統的瓶頸。
【5】監視器
Graphic Monitor是為系統管理員提供整個集羣系統的監視器,它可以監視系統的狀態。Graphic Monitor是基於瀏覽器的,所以無論管理員在本地還是異地都可以監測系統的狀況。為了安全的原因,瀏覽器要通過HTTPS(Secure HTTP)協議和身份認證後,才能進行系統監測,並進行系統的配置和管理。

LVS優點

1、開源,免費
2、在網上能找到一些相關技術資源
3、具有軟件負載均衡的一些優點

LVS缺點

1、最核心的就是沒有可靠的支持服務,沒有人對其結果負責;
2、功能比較簡單,支持複雜應用的負載均衡能力較差,如算法較少等;
3、開啓隧道方式需重編譯內核;
4、配置複雜;
5、主要應用於LINUX,沒有專門用於WINDOWS的版本,不過可以通過配置,使windows成為LVS集羣中的real server(win2003、win2008中)。
參考資料