【Linux】LVS --Linux虛擬伺服器

楊奇龍發表於2010-10-24

        LVS是一個開源的軟體,由畢業於國防科技大學的章文嵩博士於1998年5月創立,可以實現LINUX平臺下的簡單負載均衡。LVS是Linux Virtual Server的縮寫,意思是Linux虛擬伺服器。

 LVS叢集採用IP負載均衡技術和基於內容請求分發技術。排程器具有很好的吞吐率,將請求均衡地轉移到不同的伺服器上執行,且排程器自動遮蔽掉伺服器的故障,從而將一組伺服器構成一個高效能的、高可用的虛擬伺服器。整個伺服器叢集的結構對客戶是透明的,而且無需修改客戶端和伺服器端的程式。為此,在設計時需要考慮系統的透明性、可伸縮性、高可用性和易管理性。一般來說,LVS叢集採用三層結構,其主要組成部分為:   
A、負載排程器(load balancer),它是整個叢集對外面的前端機,負責將客戶的請求傳送到一組伺服器上執行,而客戶認為服務是來自一個IP地址(我們可稱之為虛擬IP地址)上的。  
B、伺服器池(server pool),是一組真正執行客戶請求的伺服器,執行的服務有WEB、MAIL、FTP和DNS等。
C、共享儲存(shared storage),它為伺服器池提供一個共享的儲存區,這樣很容易使得伺服器池擁有相同的內容,提供相同的服務。   
    排程器是伺服器叢集系統的唯一入口點(Single Entry Point),它可以採用IP負載均衡技術、基於內容請求分發技術或者兩者相結合。在IP負載均衡技術中,需要伺服器池擁有相同的內容提供相同的服務。當客戶請求到達時,排程器只根據伺服器負載情況和設定的排程演算法從伺服器池中選出一個伺服器,將該請求轉發到選出的伺服器,並記錄這個排程;當這個請求的其他報文到達,也會被轉發到前面選出的伺服器。在基於內容請求分發技術中,伺服器可以提供不同的服務,當客戶請求到達時,排程器可根據請求的內容選擇伺服器執行請求。因為所有的操作都是在Linux作業系統核心空間中將完成的,它的排程開銷很小,所以它具有很高的吞吐率。伺服器池的結點數目是可變的。當整個系統收到的負載超過目前所有結點的處理能力時,可以在伺服器池中增加伺服器來滿足不斷增長的請求負載。對大多數網路服務來說,請求間不存在很強的相關性,請求可以在不同的結點上並行執行,所以整個系統的效能基本上可以隨著伺服器池的結點數目增加而線性增長。 共享儲存通常是資料庫、網路檔案系統或者分散式檔案系統。伺服器結點需要動態更新的資料一般儲存在資料庫系統中,同時資料庫會保證併發訪問時資料的一致性。靜態的資料可以儲存在網路檔案系統(如NFS/CIFS)中,但網路檔案系統的伸縮能力有限,一般來說,NFS/CIFS伺服器只能支援3~6個繁忙的伺服器結點。對於規模較大的叢集系統,可以考慮用分散式檔案系統,如AFS、GFS、Coda和Intermezzo等。分散式檔案系統可為各伺服器提供共享的儲存區,它們訪問分散式檔案系統就像訪問本地檔案系統一樣,同時分散式檔案系統可提供良好的伸縮性和可用性。此外,當不同伺服器上的應用程式同時讀寫訪問分散式檔案系統上同一資源時,應用程式的訪問衝突需要消解才能使得資源處於一致狀態。這需要一個分散式鎖管理器(Distributed Lock Manager),它可能是分散式檔案系統內部提供的,也可能是外部的。開發者在寫應用程式時,可以使用分散式鎖管理器來保證應用程式在不同結點上併發訪問的一致性。   負載排程器、伺服器池和共享儲存系統透過高速網路相連線,如100Mbps交換網路、Myrinet和Gigabit網路等。使用高速的網路,主要為避免當系統規模擴大時網際網路絡成為整個系統的瓶頸。   Graphic Monitor是為系統管理員提供整個叢集系統的監視器,它可以監視系統的狀態。Graphic Monitor是基於瀏覽器的,所以無論管理員在本地還是異地都可以監測系統的狀況。為了安全的原因,瀏覽器要透過HTTPS(Secure HTTP)協議和身份認證後,才能進行系統監測,並進行系統的配置和管理。
編輯本段LVS的IP負載均衡
  可伸縮網路服務的幾種結構,它們都需要一個前端的負載排程器(或者多個進行主從備份)。我們先分析實現虛擬網路服務的主要技術,指出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負載均衡技術
 優點:
  1、開源,免費   
    2、在網上能找到一些相關技術資源   
    3、具有軟體負載均衡的一些優點
缺點:
  1、具有開源產品常有的缺點,最核心的就是沒有可靠的支援服務,沒有人對其結果負責;
    2、功能比較簡單,支援複雜應用的負載均衡能力較差,如演算法較少等;
    3、開啟隧道方式需重編譯核心;   
    4、配置複雜;   
    5、只支援LINUX,如果應用還包括WINDOWS、 SOLARIS等就不行了。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22664653/viewspace-676626/,如需轉載,請註明出處,否則將追究法律責任。

相關文章