VLAN 基礎知識

為什麼需要VLAN

1. 什麼是VLAN?

VLAN(Virtual LAN),翻譯成中文是「虛擬區域網」。LAN可以是由少數幾台家用計算機構成的網路,也可以是數以百計的計算機構成的企業網路。VLAN所指的LAN特指使用路由器分割的網路——也就是廣播域。

在此讓我們先複習一下廣播域的概念。廣播域,指的是廣播幀(目標MAC地址全部為1)所能傳遞到的範圍,亦即能夠直接通信的範圍。嚴格地說,並不僅僅是廣播幀,多播幀(Multicast Frame)和目標不明的單播幀(Unknown Unicast Frame)也能在同一個廣播域中暢行無阻。

本來,二層交換機只能構建單一的廣播域,不過使用VLAN功能後,它能夠將網路分割成多個廣播域。

2.未分割廣播域時……

那麼,為什麼需要分割廣播域呢?那是因為,如果僅有一個廣播域,有可能會影響到網路整體的傳輸性能。具體原因,請參看附圖加深理解。

圖中,是一個由5台二層交換機(交換機1~5)連接了大量客戶機構成的網路。假設這時,計算機A需要與計算機B通信。在基於乙太網的通信中,必須在數據幀中指定目標MAC地址才能正常通信,因此計算機A必須先廣播「ARP請求(ARP Request)信息」,來嘗試獲取計算機B的MAC地址。

交換機1收到廣播幀(ARP請求)後,會將它轉發給除接收埠外的其他所有埠,也就是Flooding了。接著,交換機2收到廣播幀後也會Flooding。交換機3、4、5也還會Flooding。最終ARP請求會被轉發到同一網路中的所有客戶機上。

請大家注意一下,這個ARP請求原本是為了獲得計算機B的MAC地址而發出的。也就是說:只要計算機B能收到就萬事大吉了。可是事實上,數據幀卻傳遍整個網路,導致所有的計算機都收到了它。如此一來,一方面廣播信息消耗了網路整體的帶寬,另一方面,收到廣播信息的計算機還要消耗一部分CPU時間來對它進行處理。造成了網路帶寬和CPU運算能力的大量無謂消耗。

3. 廣播信息是那麼經常發出的嗎?

讀到這裡,您也許會問:廣播信息真是那麼頻繁出現的嗎?

答案是:是的!實際上廣播幀會非常頻繁地出現。利用TCP/IP協議棧通信時,除了前面出現的ARP外,還有可能需要發出DHCP、RIP等很多其他類型的廣播信息。

ARP廣播,是在需要與其他主機通信時發出的。當客戶機請求DHCP伺服器分配IP地址時,就必須發出DHCP的廣播。而使用RIP作為路由協議時,每隔30秒路由器都會對鄰近的其他路由器廣播一次路由信息。RIP以外的其他路由協議使用多播傳輸路由信息,這也會被交換機轉發(Flooding)。除了TCP/IP以外,NetBEUI、IPX和Apple Talk等協議也經常需要用到廣播。例如在Windows下雙擊打開「網路計算機」時就會發出廣播(多播)信息。(Windows XP除外……)

總之,廣播就在我們身邊。下面是一些常見的廣播通信:

(1)ARP請求:建立IP地址和MAC地址的映射關係。

(2)RIP:一種路由協議。

(3)DHCP:用於自動設定IP地址的協議。

(4)NetBEUI:Windows下使用的網路協議。

(5)IPX:NovellNetware使用的網路協議。

(6)Apple Talk:蘋果公司的Macintosh計算機使用的網路協議。

如果整個網路只有一個廣播域,那麼一旦發出廣播信息,就會傳遍整個網路,並且對網路中的主機帶來額外的負擔。因此,在設計LAN時,需要注意如何才能有效地分割廣播域。

4.廣播域的分割與VLAN的必要性

分割廣播域時,一般都必須使用到路由器。使用路由器後,可以以路由器上的網路介面(LAN Interface)為單位分割廣播域。

但是,通常情況下路由器上不會有太多的網路介面,其數目多在1~4個左右。隨著寬頻連接的普及,寬頻路由器(或者叫IP共享器)變得較為常見,但是需要注意的是,它們上面雖然帶著多個(一般為4個左右)連接LAN一側的網路介面,但那實際上是路由器內置的交換機,並不能分割廣播域。

況且使用路由器分割廣播域的話,所能分割的個數完全取決於路由器的網路介面個數,使得用戶無法自由地根據實際需要分割廣播域。

與路由器相比,二層交換機一般帶有多個網路介面。因此如果能使用它分割廣播域,那麼無疑運用上的靈活性會大大提高。

用於在二層交換機上分割廣播域的技術,就是VLAN。通過利用VLAN,我們可以自由設計廣播域的構成,提高網路設計的自由度。

實現VLAN的機制

1. 實現VLAN的機制

在理解了「為什麼需要VLAN」之後,接下來讓我們來了解一下交換機是如何使用VLAN分割廣播域的。

首先,在一台未設置任何VLAN的二層交換機上,任何廣播幀都會被轉發給除接收埠外的所有其他埠(Flooding)。例如,計算機A發送廣播信息後,會被轉發給埠2、3、4。

這時,如果在交換機上生成紅、藍兩個VLAN;同時設置埠1、2屬於紅色VLAN、埠3、4屬於藍色VLAN。再從A發出廣播幀的話,交換機就只會把它轉發給同屬於一個VLAN的其他埠——也就是同屬於紅色VLAN的埠2,不會再轉發給屬於藍色VLAN的埠。

同樣,C發送廣播信息時,只會被轉發給其他屬於藍色VLAN的埠,不會被轉發給屬於紅色VLAN的埠。

就這樣,VLAN通過限制廣播幀轉發的範圍分割了廣播域。上圖中為了便於說明,以紅、藍兩色識別不同的VLAN,在實際使用中則是用「VLAN ID」來區分的。

2.直觀地描述VLAN

如果要更為直觀地描述VLAN的話,我們可以把它理解為將一台交換機在邏輯上分割成了數台交換機。在一台交換機上生成紅、藍兩個VLAN,也可以看作是將一台交換機換做一紅一藍兩台虛擬的交換機。

在紅、藍兩個VLAN之外生成新的VLAN時,可以想像成又添加了新的交換機。

但是,VLAN生成的邏輯上的交換機是互不相通的。因此,在交換機上設置VLAN後,如果未做其他處理,VLAN間是無法通信的。

明明接在同一台交換機上,但卻偏偏無法通信——這個事實也許讓人難以接受。但它既是VLAN方便易用的特徵,又是使VLAN令人難以理解的原因。

3. 需要VLAN間通信時怎麼辦

那麼,當我們需要在不同的VLAN間通信時又該如何是好呢?

請大家再次回憶一下:VLAN是廣播域。而通常兩個廣播域之間由路由器連接,廣播域之間來往的數據包都是由路由器中繼的。因此,VLAN間的通信也需要路由器提供中繼服務,這被稱作「VLAN間路由」。

VLAN間路由,可以使用普通的路由器,也可以使用三層交換機。其中的具體內容,等有機會再細說吧。在這裡希望大家先記住不同VLAN間互相通信時需要用到路由功能。

VLAN的訪問鏈接(Access Link)

1.交換機的埠類型

交換機的埠,可以分為以下兩種:

(1)訪問鏈接(Access Link)

(2)匯聚鏈接(Trunk Link)

接下來就讓我們來依次學習這兩種不同埠的特徵。這一講,首先學習「訪問鏈接」。

2.訪問鏈接

訪問鏈接,指的是「只屬於一個VLAN,且僅向該VLAN轉發數據幀」的埠。在大多數情況下,訪問鏈接所連的是客戶機。

通常設置VLAN的順序是:

(1)生成VLAN

(2)設定訪問鏈接(決定各埠屬於哪一個VLAN)

設定訪問鏈接的手法,可以是事先固定的、也可以是根據所連的計算機而動態改變設定。前者被稱為「靜態VLAN」、後者自然就是「動態VLAN」了。

● 靜態VLAN——基於埠

靜態VLAN又被稱為基於埠的VLAN(PortBased VLAN)。顧名思義,就是明確指定各埠屬於哪個VLAN的設定方法。

由於需要一個個埠地指定,因此當網路中的計算機數目超過一定數字(比如數百台)後,設定操作就會變得煩雜無比。並且,客戶機每次變更所連埠,都必須同時更改該埠所屬VLAN的設定——這顯然不適合那些需要頻繁改變拓補結構的網路。

● 動態VLAN

另一方面,動態VLAN則是根據每個埠所連的計算機,隨時改變埠所屬的VLAN。這就可以避免上述的更改設定之類的操作。動態VLAN可以大致分為3類:

(1)基於MAC地址的VLAN(MAC Based VLAN)

(2)基於子網的VLAN(Subnet Based VLAN)

(3)基於用戶的VLAN(User Based VLAN)

其間的差異,主要在於根據OSI參照模型哪一層的信息決定埠所屬的VLAN。

● 基於MAC地址的VLAN

基於MAC地址的VLAN,就是通過查詢並記錄埠所連計算機上網卡的MAC地址來決定埠的所屬。假定有一個MAC地址「A」被交換機設定為屬於VLAN 「10」,那麼不論MAC地址為「A」的這台計算機連在交換機哪個埠,該埠都會被劃分到VLAN 10中去。計算機連在埠1時,埠1屬於VLAN 10;而計算機連在埠2時,則是埠2屬於VLAN 10。

由於是基於MAC地址決定所屬VLAN的,因此可以理解為這是一種在OSI的第二層設定訪問鏈接的辦法。

但是,基於MAC地址的VLAN,在設定時必須調查所連接的所有計算機的MAC地址並加以登錄。而且如果計算機交換了網卡,還是需要更改設定。

● 基於IP地址的VLAN

基於子網的VLAN,則是通過所連計算機的IP地址,來決定埠所屬VLAN的。不像基於MAC地址的VLAN,即使計算機因為交換了網卡或是其他原因導致MAC地址改變,只要它的IP地址不變,就仍可以加入原先設定的VLAN。

因此,與基於MAC地址的VLAN相比,能夠更為簡便地改變網路結構。IP地址是OSI參照模型中第三層的信息,所以我們可以理解為基於子網的VLAN是一種在OSI的第三層設定訪問鏈接的方法。

基於用戶的VLAN,則是根據交換機各埠所連的計算機上當前登錄的用戶,來決定該埠屬於哪個VLAN。這裡的用戶識別信息,一般是計算機操作系統登錄的用戶,比如可以是Windows域中使用的用戶名。這些用戶名信息,屬於OSI第四層以上的信息。

總的來說,決定埠所屬VLAN時利用的信息在OSI中的層面越高,就越適於構建靈活多變的網路。

VLAN的匯聚鏈接(Trunk Link)

1.需要設置跨越多台交換機的VLAN時……

到此為止,我們學習的都是使用單台交換機設置VLAN時的情況。那麼,如果需要設置跨越多台交換機的VLAN時又如何呢?

在規劃企業級網路時,很有可能會遇到隸屬於同一部門的用戶分散在同一座建築物中的不同樓層的情況,這時可能就需要考慮到如何跨越多台交換機設置VLAN的問題了。假設有如下圖所示的網路,且需要將不同樓層的A、C和B、D設置為同一個VLAN。

這時最關鍵的就是「交換機1和交換機2該如何連接才好呢?」

最簡單的方法,自然是在交換機1和交換機2上各設一個紅、藍VLAN專用的介面並互聯了。

但是,這個辦法從擴展性和管理效率來看都不好。例如,在現有網路基礎上再新建VLAN時,為了讓這個VLAN能夠互通,就需要在交換機間連接新的網線。建築物樓層間的縱向布線是比較麻煩的,一般不能由基層管理人員隨意進行。並且,VLAN越多,樓層間(嚴格地說是交換機間)互聯所需的埠也越來越多,交換機埠的利用效率低是對資源的一種浪費、也限制了網路的擴展。

為了避免這種低效率的連接方式,人們想辦法讓交換機間互聯的網線集中到一根上,這時使用的就是匯聚鏈接(Trunk Link)。

2.何謂匯聚鏈接?

匯聚鏈接(Trunk Link)指的是能夠轉發多個不同VLAN的通信的埠。

匯聚鏈路上流通的數據幀,都被附加了用於識別分屬於哪個VLAN的特殊信息。

現在再讓我們回過頭來考慮一下剛才那個網路如果採用匯聚鏈路又會如何呢?用戶只需要簡單地將交換機間互聯的埠設定為匯聚鏈接就可以了。這時使用的網線還是普通的UTP線,而不是什麼其他的特殊布線。圖例中是交換機間互聯,因此需要用交叉線來連接。

接下來,讓我們具體看看匯聚鏈接是如何實現跨越交換機間的VLAN的。

A發送的數據幀從交換機1經過匯聚鏈路到達交換機2時,在數據幀上附加了表示屬於紅色VLAN的標記。

交換機2收到數據幀後,經過檢查VLAN標識發現這個數據幀是屬於紅色VLAN的,因此去除標記後根據需要將復原的數據幀只轉發給其他屬於紅色VLAN的埠。這時的轉送,是指經過確認目標MAC地址並與MAC地址列表比對後只轉發給目標MAC地址所連的埠。只有當數據幀是一個廣播幀、多播幀或是目標不明的幀時,它才會被轉發到所有屬於紅色VLAN的埠。

藍色VLAN發送數據幀時的情形也與此相同。

通過匯聚鏈路時附加的VLAN識別信息,有可能支持標準的「IEEE 802.1Q」協議,也可能是Cisco產品獨有的「ISL(Inter Switch Link)」。如果交換機支持這些規格,那麼用戶就能夠高效率地構築橫跨多台交換機的VLAN。

另外,匯聚鏈路上流通著多個VLAN的數據,自然負載較重。因此,在設定匯聚鏈接時,有一個前提就是必須支持100Mbps以上的傳輸速度。

另外,默認條件下,匯聚鏈接會轉發交換機上存在的所有VLAN的數據。換一個角度看,可以認為匯聚鏈接(埠)同時屬於交換機上所有的VLAN。由於實際應用中很可能並不需要轉發所有VLAN的數據,因此為了減輕交換機的負載、也為了減少對帶寬的浪費,我們可以通過用戶設定限制能夠經由匯聚鏈路互聯的VLAN。

關於IEEE 802.1Q和ISL的具體內容,將在下一講中提到。

3.訪問鏈接的總結

綜上所述,設定訪問鏈接的手法有靜態VLAN和動態VLAN兩種,其中動態VLAN又可以繼續細分成幾個小類。

其中基於子網的VLAN和基於用戶的VLAN有可能是網路設備廠商使用獨有的協議實現的,不同廠商的設備之間互聯有可能出現兼容性問題;因此在選擇交換機時,一定要注意事先確認。

下表總結了靜態VLAN和動態VLAN的相關信息。

種類解說

靜態VLAN(基於埠的VLAN)將交換機的各埠固定指派給VLAN

動態VLAN基於MAC地址的VLAN根據各埠所連計算機的MAC地址設定

基於子網的VLAN根據各埠所連計算機的IP地址設定

基於用戶的VLAN根據埠所連計算機上登錄用戶設定

VLAN的匯聚方式——IEEE802.1Q與ISL

1.匯聚方式

在交換機的匯聚鏈接上,可以通過對數據幀附加VLAN信息,構建跨越多台交換機的VLAN。

附加VLAN信息的方法,最具有代表性的有:

(1)IEEE 802.1Q

(2)ISL

現在就讓我們看看這兩種協議分別如何對數據幀附加VLAN信息。

2.IEEE 802.1Q

IEEE 802.1Q,俗稱「Dot One Q」,是經過IEEE認證的對數據幀附加VLAN識別信息的協議。

在此,請大家先回憶一下乙太網數據幀的標準格式。

IEEE 802.1Q所附加的VLAN識別信息,位於數據幀中「發送源MAC地址」與「類別域」(Type Field)之間。具體內容為2位元組的TPID(Tag Protocol IDentifier)和2位元組的TCI(Tag Control Information),共計4位元組。

在數據幀中添加了4位元組的內容,那麼CRC值自然也會有所變化。這時數據幀上的CRC是插入TPID、TCI後,對包括它們在內的整個數據幀重新計算後所得的值。

而當數據幀離開匯聚鏈路時,TPID和TCI會被去除,這時還會進行一次CRC的重新計算。

TPID欄位在乙太網報文中所處位置與不帶VLAN Tag的報文中協議類型欄位所處位置相同。TPID的值固定為0x8100,它標示網路幀承載的802.1Q類型,交換機通過它來確定數據幀內附加了基於IEEE 802.1Q的VLAN信息。而實質上的VLAN ID,是TCI中的12位元。由於總共有12位,因此最多可供識別4096個VLAN。

基於IEEE 802.1Q附加的VLAN信息,就像在傳遞物品時附加的標籤。因此,它也被稱作「標籤型VLAN」(Tagging VLAN)。

3.ISL(Inter Switch Link)

ISL,是Cisco產品支持的一種與IEEE 802.1Q類似的、用於在匯聚鏈路上附加VLAN信息的協議。

使用ISL後,每個數據幀頭部都會被附加26位元組的「ISL包頭(ISL Header)」,並且在幀尾帶上通過對包括ISL包頭在內的整個數據幀進行計算後得到的4位元組CRC值。換而言之,就是總共增加了30位元組的信息。

在使用ISL的環境下,當數據幀離開匯聚鏈路時,只要簡單地去除ISL包頭和新CRC就可以了。由於原先的數據幀及其CRC都被完整保留,因此無需重新計算CRC。

ISL有如用ISL包頭和新CRC將原數據幀整個包裹起來,因此也被稱為「封裝型VLAN」(Encapsulated VLAN)。

需要注意的是,不論是IEEE802.1Q的「Tagging VLAN」,還是ISL的「Encapsulated VLAN」,都不是很嚴密的稱謂。不同的書籍與參考資料中,上述詞語有可能被混合使用,因此需要大家在學習時格外注意。

並且由於ISL是Cisco獨有的協議,因此只能用於Cisco網路設備之間的互聯。

VLAN間路由

1.VLAN間路由的必要性

根據目前為止學習的知識,我們已經知道兩台計算機即使連接在同一台交換機上,只要所屬的VLAN不同就無法直接通信。接下來我們將要學習的就是如何在不同的VLAN間進行路由,使分屬不同VLAN的主機能夠互相通信。

首先,先來複習一下為什麼不同VLAN間不通過路由就無法通信。在LAN內的通信,必須在數據幀頭中指定通信目標的MAC地址。而為了獲取MAC地址,TCP/IP協議下使用的是ARP。ARP解析MAC地址的方法,則是通過廣播。也就是說,如果廣播報文無法到達,那麼就無從解析MAC地址,亦即無法直接通信。

計算機分屬不同的VLAN,也就意味著分屬不同的廣播域,自然收不到彼此的廣播報文。因此,屬於不同VLAN的計算機之間無法直接互相通信。為了能夠在VLAN間通信,需要利用OSI參照模型中更高一層——網路層的信息(IP地址)來進行路由。關於路由的具體內容,以後有機會再詳細解說吧。

路由功能,一般主要由路由器提供。但在今天的區域網里,我們也經常利用帶有路由功能的交換機——三層交換機(Layer 3 Switch)來實現。接下來就讓我們分別看看使用路由器和三層交換機進行VLAN間路由時的情況。

2.使用路由器進行VLAN間路由

在使用路由器進行VLAN間路由時,與構建橫跨多台交換機的VLAN時的情況類似,我們還是會遇到「該如何連接路由器與交換機」這個問題。路由器和交換機的接線方式,大致有以下兩種:

(1)將路由器與交換機上的每個VLAN分別連接

(2)不論VLAN有多少個,路由器與交換機都只用一條網線連接

最容易想到的,當然還是「把路由器和交換機以VLAN為單位分別用網線連接」了。將交換機上用於和路由器互聯的每個埠設為訪問鏈接(Access Link),然後分別用網線與路由器上的獨立埠互聯。如下圖所示,交換機上有2個VLAN,那麼就需要在交換機上預留2個埠用於與路由器互聯;路由器上同樣需要有2個埠;兩者之間用2條網線分別連接。

如果採用這個辦法,大家應該不難想像它的擴展性很成問題。每增加一個新的VLAN,都需要消耗路由器的埠和交換機上的訪問鏈接,而且還需要重新布設一條網線。而路由器,通常不會帶有太多LAN介面的。新建VLAN時,為了對應增加的VLAN所需的埠,就必須將路由器升級成帶有多個LAN介面的高端產品,這部分成本、還有重新布線所帶來的開銷,都使得這種接線法成為一種不受歡迎的辦法。

那麼,第二種辦法「不論VLAN數目多少,都只用一條網線連接路由器與交換機」呢?當使用一條網線連接路由器與交換機、進行VLAN間路由時,需要用到匯聚鏈接。

具體實現過程為:首先將用於連接路由器的交換機埠設為匯聚鏈接(Trunk Link),而路由器上的埠也必須支持匯聚鏈路。雙方用於匯聚鏈路的協議自然也必須相同。接著在路由器上定義對應各個VLAN的「子介面」(Sub Interface)。儘管實際與交換機連接的物理埠只有一個,但在理論上我們可以把它分割為多個虛擬埠。

VLAN將交換機從邏輯上分割成了多台,因而用於VLAN間路由的路由器,也必須擁有分別對應各個VLAN的虛擬介面。

採用這種方法的話,即使之後在交換機上新建VLAN,仍只需要一條網線連接交換機和路由器。用戶只需要在路由器上新設一個對應新VLAN的子介面就可以了。與前面的方法相比,擴展性要強得多,也不用擔心需要升級LAN介面數不足的路由器或是重新布線。

3.同一VLAN內的通信

接下來,我們繼續學習使用匯聚鏈路連接交換機與路由器時,VLAN間路由是如何進行的。如下圖所示,為各台計算機以及路由器的子介面設定IP地址。

紅色VLAN(VLAN ID=1)的網路地址為192.168.1.0/24,藍色VLAN(VLAN ID=2)的網路地址為192.168.2.0/24。各計算機的MAC地址分別為A/B/C/D,路由器匯聚鏈接埠的MAC地址為R。交換機通過對各埠所連計算機MAC地址的學習,生成如下的MAC地址列表。

首先考慮計算機A與同一VLAN內的計算機B之間通信時的情形。

計算機A發出ARP請求信息,請求解析B的MAC地址。交換機收到數據幀後,檢索MAC地址列表中與收信埠同屬一個VLAN的表項。結果發現,計算機B連接在埠2上,於是交換機將數據幀轉發給埠2,最終計算機B收到該幀。收發信雙方同屬一個VLAN之內的通信,一切處理均在交換機內完成。

4.不同VLAN間的通信

接下來是這一講的核心內容,不同VLAN間的通信。讓我們來考慮一下計算機A與計算機C之間通信時的情況。

計算機A從通信目標的IP地址(192.168.2.1)得出C與本機不屬於同一個網段。因此會向設定的默認網關(DefaultGateway,GW)轉發數據幀。在發送數據幀之前,需要先用ARP獲取路由器的MAC地址。

得到路由器的MAC地址R後,接下來就是按圖中所示的步驟發送往C去的數據幀。①的數據幀中,目標MAC地址是路由器的地址R、但內含的目標IP地址仍是最終要通信的對象C的地址。這一部分的內容,涉及到區域網內經過路由器轉發時的通信步驟,有機會再詳細解說吧。

交換機在埠1上收到①的數據幀後,檢索MAC地址列表中與埠1同屬一個VLAN的表項。由於匯聚鏈路會被看作屬於所有的VLAN,因此這時交換機的埠6也屬於被參照對象。這樣交換機就知道往MAC地址R發送數據幀,需要經過埠6轉發。

從埠6發送數據幀時,由於它是匯聚鏈接,因此會被附加上VLAN識別信息。由於原先是來自紅色VLAN的數據幀,因此如圖中②所示,會被加上紅色VLAN的識別信息後進入匯聚鏈路。路由器收到②的數據幀後,確認其VLAN識別信息,由於它是屬於紅色VLAN的數據幀,因此交由負責紅色VLAN的子介面接收。

接著,根據路由器內部的路由表,判斷該向哪裡中繼。

由於目標網路192.168.2.0/24是藍色VLAN,,且該網路通過子介面與路由器直連,因此只要從負責藍色VLAN的子介面轉發就可以了。這時,數據幀的目標MAC地址被改寫成計算機C的目標地址;並且由於需要經過匯聚鏈路轉發,因此被附加了屬於藍色VLAN的識別信息。這就是圖中③的數據幀。

交換機收到③的數據幀後,根據VLAN標識信息從MAC地址列表中檢索屬於藍色VLAN的表項。由於通信目標——計算機C連接在埠3上、且埠3為普通的訪問鏈接,因此交換機會將數據幀去除VLAN識別信息後(數據幀④)轉發給埠3,最終計算機C才能成功地收到這個數據幀。

進行VLAN間通信時,即使通信雙方都連接在同一台交換機上,也必須經過:「發送方——交換機——路由器——交換機——接收方」這樣一個流程。

三層交換機

1.使用路由器進行VLAN間路由時的問題

現在,我們知道只要能提供VLAN間路由,就能夠使分屬不同VLAN的計算機互相通信。但是,如果使用路由器進行VLAN間路由的話,隨著VLAN之間流量的不斷增加,很可能導致路由器成為整個網路的瓶頸。

交換機使用被稱為ASIC(ApplicationSpecified Integrated Circuit)的專用硬體晶元處理數據幀的交換操作,在很多機型上都能實現以纜線速度(Wired Speed)交換。而路由器,則基本上是基於軟體處理的。即使以纜線速度接收到數據包,也無法在不限速的條件下轉發出去,因此會成為速度瓶頸。就VLAN間路由而言,流量會集中到路由器和交換機互聯的匯聚鏈路部分,這一部分尤其特別容易成為速度瓶頸。並且從硬體上看,由於需要分別設置路由器和交換機,在一些空間狹小的環境里可能連設置的場所都成問題。

2.三層交換機(Layer 3 Switch)

為了解決上述問題,三層交換機應運而生。三層交換機,本質上就是「帶有路由功能的(二層)交換機」。路由屬於OSI參照模型中第三層網路層的功能,因此帶有第三層路由功能的交換機才被稱為「三層交換機」。

關於三層交換機的內部結構,可以參照下面的簡圖。

在一台本體內,分別設置了交換機模塊和路由器模塊;而內置的路由模塊與交換模塊相同,使用ASIC硬體處理路由。因此,與傳統的路由器相比,可以實現高速路由。並且,路由與交換模塊是匯聚鏈接的,由於是內部連接,可以確保相當大的帶寬。

● 使用三層交換機進行VLAN間路由(VLAN內通信)

在三層交換機內部數據究竟是怎樣傳播的呢?基本上,它和使用匯聚鏈路連接路由器與交換機時的情形相同。

假設有如下圖所示的4台計算機與三層交換機互聯。當使用路由器連接時,一般需要在LAN介面上設置對應各VLAN的子介面;而三層交換機則是在內部生成「VLAN介面」(VLAN Interface)。VLAN介面,是用於各VLAN收發數據的介面。(註:在Cisco的Catalyst系列交換機上,VLAN Interface被稱為SVI——Switched Virtual Interface)

為了與使用路由器進行VLAN間路由對比,讓我們同樣來考慮一下計算機A與計算機B之間通信時的情況。首先是目標地址為B的數據幀被發到交換機;通過檢索同一VLAN的MAC地址列表發現計算機B連在交換機的埠2上;因此將數據幀轉發給埠2。

● 使用三層交換機進行VLAN間路由(VLAN間通信)

接下來設想一下計算機A與計算機C間通信時的情形。針對目標IP地址,計算機A可以判斷出通信對象不屬於同一個網路,因此向默認網關發送數據(Frame 1)。

交換機通過檢索MAC地址列表後,經由內部匯聚鏈接,將數據幀轉發給路由模塊。在通過內部匯聚鏈路時,數據幀被附加了屬於紅色VLAN的VLAN識別信息(Frame 2)。

路由模塊在收到數據幀時,先由數據幀附加的VLAN識別信息分辨出它屬於紅色VLAN,據此判斷由紅色VLAN介面負責接收並進行路由處理。因為目標網路192.168.2.0/24是直連路由器的網路、且對應藍色VLAN;因此,接下來就會從藍色VLAN介面經由內部匯聚鏈路轉發回交換模塊。在通過匯聚鏈路時,這次數據幀被附加上屬於藍色VLAN的識別信息(Frame 3)。

交換機收到這個幀後,檢索藍色VLAN的MAC地址列表,確認需要將它轉發給埠3。由於埠3是通常的訪問鏈接,因此轉發前會先將VLAN識別信息去除(Frame 4)。最終,計算機C成功地收到交換機轉發來的數據幀。

整體的流程,與使用外部路由器時的情況十分相似——都需要經過「發送方→交換模塊→路由模塊→交換模塊→接收方」。

加速VLAN間通信的手段

1.流(Flow)

根據到此為止的學習,我們已經知道VLAN間路由,必須經過外部的路由器或是三層交換機的內置路由模塊。但是,有時並不是所有的數據都需要經過路由器(或路由模塊)。

例如,使用FTP(File Transfer Protocol)傳輸容量為數MB以上的較大的文件時,由於MTU的限制,IP協議會將數據分割成小塊後傳輸、並在接收方重新組合。這些被分割的數據,「發送的目標」是完全相同的。發送目標相同,也就意味著同樣的目標IP地址、目標埠號(註:特彆強調一下,這裡指的是TCP/UDP埠)。自然,源IP地址、源埠號也應該相同。這樣一連串的數據流被稱為「流」(Flow)。

只要將流最初的數據正確地路由以後,後繼的數據理應也會被同樣地路由。

據此,後繼的數據不再需要路由器進行路由處理;通過省略反覆進行的路由操作,可以進一步提高VLAN間路由的速度。

2.加速VLAN間路由的機制

接下來,讓我們具體考慮一下該如何使用三層交換機進行高速VLAN間路由。

首先,整個流的第一塊數據,照常由交換機轉發→路由器路由→再次由交換機轉發到目標所連埠。這時,將第一塊數據路由的結果記錄到緩存里保存下來。需要記錄的信息有:

(1)目標IP地址

(2)源IP地址

(3)目標TCP/UDP埠號

(4)源TCP/UDP埠號

(5)接收埠號(交換機)

(6)轉發埠號(交換機)

(7)轉發目標MAC地址

等等。

同一個流的第二塊以後的數據到達交換機後,直接通過查詢先前保存在緩存中的信息查出「轉發埠號」後就可以轉發給目標所連埠了。

這樣一來,就不需要再一次次經由內部路由模塊中繼,而僅憑交換機內部的緩存信息就足以判斷應該轉發的埠。

這時,交換機會對數據幀進行由路由器中繼時相似的處理,例如改寫MAC地址、IP包頭中的TTL和Check Sum校驗碼信息等。

通過在交換機上緩存路由結果,實現了以纜線速度(Wired Speed)接收發送方傳輸來數據的數據、並且能夠全速路由、轉發給接收方。

需要注意的是,類似的加速VLAN間路由的手法多由各廠商獨有的技術所實現,並且該功能的稱謂也因廠商而異。例如,在Cisco的Catalyst系列交換機上,這種功能被稱為「多層交換」(Multi Layer Switching)。另外,除了三層交換機的內部路由模塊,外部路由器中的某些機型也支持類似的高速VLAN間路由機制。

傳統型路由器存在的意義

1.路由器的必要性

三層交換機的價格,在問世之初非常昂貴,但是現在它們的價格已經下降了許多。目前國外一些廉價機型的售價,摺合成人民幣後僅為一萬多元,而且還在繼續下降中。

既然三層交換機能夠提供比傳統型路由器更為高速的路由處理,那麼網路中還有使用路由器的必要嗎?

答案是:「是」。

使用路由器的必要性,主要表現在以下幾個方面:

(1)用於與WAN連接

三層交換機終究是「交換機」。也就是說,絕大多數機型只配有LAN(乙太網)介面。在少數高端交換機上也有用於連接WAN的串列介面或是ATM介面,但在大多數情況下,連接WAN還是需要用到路由器。

(2)保證網路安全

在三層交換機上,通過數據包過濾也能確保一定程度的網路安全。但是使用路由器所提供的各種網路安全功能,用戶可以構建更為安全可靠的網路。

路由器提供的網路安全功能中,除了最基本的數據包過濾功能外,還能基於IPSec構建VPN(VirtualPrivate Network)、利用RADIUS進行用戶認證等等。

(3)支持除TCP/IP以外的異構網路架構

儘管TCP/IP已經成為當前網路協議架構的主流,但還有不少網路利用Novell Netware下的IPX/SPX或Macintosh下的AppleTalk等網路協議。三層交換機中,除了部分高端機型外基本上還只支持TCP/IP。因此,在需要使用除TCP/IP之外其他網路協議的環境下,路由器還是必不可少的。

註:在少數高端交換機上,也能支持上述路由器的功能。例如Cisco的Catalyst 6500系列,就可以選擇與WAN連接的介面模塊;還有可選的基於IPSec實現VPN的模塊;並且也能支持TCP/IP以外的其他網路協議。

2.路由器和交換機配合構建LAN的實例

下面讓我們來看一個路由器和交換機搭配構建LAN的實例。

利用在各樓層配置的二層交換機定義VLAN,連接TCP/IP客戶計算機。各樓層間的VLAN間通信,利用三層交換機的高速路由加以實現。如果網路環境要求高可靠性,還可以考慮冗餘配置三層交換機。

與WAN的連接,則通過帶有各種網路介面的路由器進行。並且,通過路由器的數據包過濾和VPN等功能實現網路安全。此外,使用路由器還能支持Novell Netware等TCP/IP之外的網路。

只有在充分掌握了二層、三層交換機以及傳統路由器的基礎上,才能做到物競其用,構築出高效率、高性價比的網路。

使用VLAN設計區域網

1.使用VLAN設計區域網的特點

通過使用VLAN構建區域網,用戶能夠不受物理鏈路的限制而自由地分割廣播域。

另外,通過先前提到的路由器與三層交換機提供的VLAN間路由,能夠適應靈活多變的網路構成。

但是,由於利用VLAN容易導致網路構成複雜化,因此也會造成整個網路的組成難以把握。

可以這樣說,在利用VLAN時,除了有「網路構成靈活多變」這個優點外,還搭配著「網路構成複雜化」這個缺點。

下面,就讓我們來看看具體的實例。

2.不使用VLAN的區域網中網路構成的改變

假設有如圖所示的由1台路由器、2台交換機構成的「不使用VLAN構建」的網路。

圖中的路由器,帶有2個LAN介面。左側的網路是192.168.1.0/24,右側是192.168.2.0/24。

現在如果想將192.168.1.0/24這個網路上的計算機A轉移到192.168.2.0/24上去,就需要改變物理連接、將A接到右側的交換機上。

並且,當需要新增一個地址為192.168.3.0/24的網路時,還要在路由器上再佔用一個LAN介面並添置一台交換機。而由於這台路由器上只帶了2個LAN介面,因此為了新增網路還必須將路由器升級為帶有3個以上LAN介面的產品。

3.使用VLAN的區域網中網路構成的改變

接下來再假設有一個由1台路由器、2台交換機構成的「使用VLAN」的區域網。交換機與交換機、交換機與路由器之間均為匯聚鏈路;並且假設192.168.1.0/24對應紅色VLAN、192.168.2.0/24對應藍色VLAN。

需要將連接在交換機1上192.168.1.0/24這個網段的計算機A轉屬192.168.2.0/24時,無需更改物理布線。只要在交換機上生成藍色VLAN,然後將計算機A所連的埠1加入到藍色VLAN中去,使它成為訪問鏈接即可。

然後,根據需要設定計算機A的IP地址、默認網關等信息就可以了。如果IP地址相關的設定是由DHCP獲取的,那麼在客戶機方面無需進行任何設定修改,就可以在不同網段間移動。

利用VLAN後,我們可以在免於改動任何物理布線的前提下,自由進行網路的邏輯設計。如果所處的工作環境恰恰需要經常改變網路布局,那麼利用VLAN的優勢就非常明顯了。

並且,當需要新增一個地址為192.168.3.0/24的網段時,也只需要在交換機上新建一個對應192.168.3.0/24的VLAN,並將所需的埠加入它的訪問鏈路就可以了。

如果網路環境中還需要利用外部路由器,則只要在路由器的匯聚埠上新增一個子介面的設定就可以完成全部操作,而不需要消耗更多的物理介面(LAN介面)。要使用的是三層交換機內部的路由模塊,則只需要新設一個VLAN介面即可。

網路環境的成長,往往是難以預測的,很可能經常會出現需要分割現有網路或是增加新網路的情況。而充分活用VLAN後,就可以輕易地解決這些問題。

4.利用VLAN而導致的網路結構複雜化

雖然利用VLAN可以靈活地構建網路,但是同時,它也帶來了網路結構複雜化的問題。

特別是由於數據流縱橫交錯,一旦發生故障時,準確定位並排除故障會比較困難。

為了便於理解數據流向的複雜化,假設有下圖所示的網路。計算機A向計算機C發送數據時,數據流的整體走向如下:

計算機A→交換機1→路由器→交換機1→交換機2→計算機C

首先計算機A向交換機1送出數據(①),其後數據被轉發給路由器(②)進行VLAN間路由。路由後的數據,再從匯聚鏈路返回交換機1(③)。由於通信目標計算機C並不直連在交換機1上,因此還需要經過匯聚鏈路轉發到交換機2(④)。在交換機2上,數據最終被轉發到C所連的埠2上,這才完成整個流程(⑤)。

在這個例子中,僅由2台交換機構成網路,其數據流已經如此複雜,如果構建橫跨多台交換機的VLAN的話,每個數據流的流向顯然會更加難以把握。

5. 網路的邏輯結構與物理結構

為了對應日漸複雜化的數據流,管理員需要從「邏輯結構」與「物理結構」兩方面入手,把握好網路的現狀。

物理結構,指的是從物理層和數據鏈路層觀察到的網路的現狀,表示了網路的物理布線形態和VLAN的設定等等。

而邏輯結構,則表示從網路層以上的層面觀察到的網路結構。下面我們就試著以路由器為中心分析一個IP網路的邏輯結構。

還是先前的那個例子,描繪了布線形態和VLAN設定的「物理結構」如下圖所示。

分析這個物理結構並轉換成以路由器為中心的邏輯結構後,會得到如下的邏輯結構圖。當我們需要進行路由或是數據包過濾的設定時,都必須在邏輯結構的基礎上進行。

把握這兩種網路結構圖的區別是十分重要的,特別是在VLAN和三層交換機大行其道的現代企業級網路當中。


推薦閱讀:

除夕練習:自動掛bilibili直播
如何評價「流氓捆綁」軟體?
網路是怎樣連接的-探索協議棧和網卡
塊存儲、文件存儲、對象存儲這三者的本質差別是什麼?
RCNN學習筆記(5):faster rcnn

TAG:VLAN | 計算機網路 |