OSPF入門童話
網絡就像一個王國,這個王國可以分成b幾個區(area),現在我們來看看區域內的某一個人(你所在的機器root)是怎樣得到一張世界地圖(routing table)的。
首先,你得跟你周圍的人(同一網段如129.102)建立基本聯系。你大叫一聲“我在這!”(發HELLO報文),于是,周圍的人知道你的存在,他們也會大叫,這樣你知道周圍大概有哪些人,你與他們之間建立了鄰居(neighbor)關系,當然,他們之間也有鄰居關系。
在你們這一群人中,最有威望(Priority優先級)的人會被推薦為首領(Designated Router)首領與你之間是上下級關系(adjacency鄰接),它會與你建立單線聯系,而不許你與其它鄰居有過多交往,他會說:“那樣做的話,街上太擠了”。
你只好通過首領來知道更多的消息了,首先,你們繼續訪問 取消訪問互通消息,他告訴你他知道的所有地圖的地名,你也會告訴他你現知道的地名,當然上也許只有你一個點。(Database Description數據庫描述報文)
你發現地名表中有你缺少的或比你新的東西,你會問他要一份更詳細的資料,他發現你的地名表中有他需要的東西,他也會向你索求新資料。(Link State Request連接狀態請求報文)
當然,你們毫不猶豫地將一份詳細資料發送給對方。(Link State Update連接狀態升級報文)
收到地圖后,互相致謝表示收到了。(Link State Ack連接狀態響應報文)現在,你已經盡你所能得到一份地圖(Link State DataBase連接狀態數據庫),你去查找地圖把到所有地方的路挑一條最近(shortest path最短路)的,記為一張表格(routing table路由表),當然以后查這份表格就知道到目的地的一條最近的路了。地圖也要收好,萬一表格上的某條路不通了可以通過圖去找一條新的路。
其實跟你有聯系的,只是周圍一群人,外面的消息要通過首領來知道。因為你的地圖是跟首領的一致,我們假設你是首領,你要去畫一份世界地圖。
你命令所有手下向你通報消息,你可以知道你這一群人的任何一點點小動靜(event事件)。你手下還會有同時屬于兩群人的家伙(同一區內兩網段),他會告訴你另一群人的地圖,當然也會把你們這一群人的地圖泄露,(不過,無所謂啦)。這樣,整個區的地圖你知道了(對于不知道的那也沒辦法,我們盡力了)。
通過不停地交換地圖,現在,整個區的人都有同樣的地圖了,住在區邊境上的人義不容辭地把這個區的地圖(精確到每一群人)發送到別的區,把別的區信息發送進來。國王會把這些邊境的人命名為骨干(backbone area)。通過骨干人士的不懈努力,現在,整個國家的地圖你都了解得一清二楚了。
有些人“里通外國”(AS Boundary Router自治系統邊界,他們知道一些“出國”(AS External route自治系統外部路由)的路,當然他們會把這些秘密公之與眾(import 引入),通過信息的傳遞,現在,你已經有一張完整的“世界地圖”了。
OSPF是這樣標記最短的路的:對于某個目的地,首先,考慮是否有同一區內部到目的地的路(intra area區域內),如果有,則在其中取一條離你最近的(花費最小),寫進你的表格中,這個目的地可能是到本群體某個人也可能是到其他群體的,對于經過其他區域的路由,你會不予考慮,跟自己人(同區域)打交道總比與外人(其他區域)打交道好;如果沒有本區的路,你只好通過別的區域了(區域間),你只要在地圖上找最近的就是了;如果你發現目的地在國外,你也只能先把它標記到你的表格上,期待什么時候王國擴張到那,你就可以把它標記到國內地圖上了。
OSPF就是這樣,給你一份“世界地圖”,并且在上面標記了最短的路,如此而已罷了。
1.2. 背景介紹
TCP/IP協議中,尋找一臺計算機到另一臺計算機的路由是很重要的.
1.要判斷是否能找到路
2.找到路后找一條短的路(花費時間最小)
3.在找路時不能循環
4.最好還應該能動態處理路由變化,如:接口的UP或DOWN,時間花費的變化,
IETF(Internet Engineering Task Force)于1988年提出的OSPF是一個基于鏈路狀態的動態路由協議,
思路如下:在自治系統中每一臺運行OSPF的由器收集各自的接口/鄰接信息稱為鏈路狀態,通過Flooding算法在整個系統廣播自己的鏈路狀態,使得在整個系統內部維護一個同步的鏈路狀態數據庫,根據這一數據庫,路由器計算出以自己為根,其它網絡節點為葉的一根最短的路徑樹,從而計算出自己到達系統內部可達的最佳路由]。
OSPF是一類Interior Gateway Protocol(內部網關協議IGP),它處理在一個自治系統中,路由器的網絡的路由表信息。
1.3. 術語和基本概念
OSPF路由協議術語:
OSPF路由協議:Open Shortest Path First 最短路徑優先協議
路由器(router):第三層的IP包交換機,以前在IP文獻中也叫做網關
自治系統(autonomy system):一群路由器通過相同的路由協議來交換路由信息,
縮寫為AS區域(area):自治系統的劃分單元,一個自治系統可以劃分為多個區域.
區域 ID(area ID):自治系統內區域的32-bit標識
內部網關協議(internal gateway protocol):屬于一個自治系統的路由器上運行的路
由協議,縮寫為IGP,每一個自治系統有一個單獨的IGP,不同的自治系統可能
運行不同的IGP。OSPF是內部網關協議的一種
路由器的ID(router ID):一個32位的標號對每個運行OSPF的路由器,在自治系
唯一的網絡(network):在這種意義下,是IP網絡/子網/超網,可能是標記了多重復合IP
地址的子網,我們把它們看成是分離的網絡,點到點的物理網絡是個特例,它們
只是被當作簡單的網,不管對它們怎樣指定IP號。
網絡掩碼(network mask):一個32位的數指示IP網絡的IP地址范圍,以十六進
制數顯示,例如一個C類網的掩碼是0xfffff00,在文字上寫成255.255.255.0。
點到點網絡(point to point network):由一對路由器簡單組成的網絡,例如一個
56Kb的串口線的連接
廣播網:網絡支持許多(兩個以上)的路由器。都有能力將地址信息發送到所有連
接的路由器上(廣播)鄰居路由器被OSPF的hello協議動態地發現,OSPF使這種
廣播能力能得到更大的應用,如果它存在,它上的每一對路由器都假定能和對方
直接相連,以太網是一個廣播網的例子。
非廣播網:網絡支持許多(兩個以上)路由器,但沒有廣播能力,鄰結點也是通過OSPF hello報文來維持,但是由于設有廣播能力一些鄰居需要靠配置來發現,在鄰居間,OSPF協議報文也是互相傳送的,X.25網是一個例子。
OSPF可以在兩種非廣播網上運行,一種是非廣播多重訪問,(NBMA)它類似于OSPF在廣播網上的操作,第二種類型叫點到多點,可看為多個點到點的連接的集合。非廣播網類型的判別依靠于對網絡的操作模式。
接口(interface):一個路由器與它連接的一個網絡 的連接稱為接口,一個接口有它的狀態信息,可以通過底層協議或是路由協議本身來得到。每個接口有一個唯一一個IP地址和掩碼(除非是不標號的點到點連接),一個接口有時也指一個連接。
鄰居路由器(neighbor):兩臺路由器有接口連向共同的網絡,鄰居關系通過OSPF hello協議被維持(通常是動態的)。
鄰接(adjacency):為交換路由而在鄰居間建立的關系,不是每對鄰居都成都為鄰接的。
連接狀態傳送(Link State Advertise):描述本地路由器或網絡的數據單元 對路由器來說,它描述了路由器的接口狀態和鄰接狀態,第一個連接狀態傳送會發送到整個路由領域,所有的連接狀態傳送組成了協議的連接狀態數據庫,這在全局范圍內使用,縮寫為LSA
連接狀態數據庫(Link State DataBase):所有連接狀態傳送組成了連接狀態數據庫.
Stub網絡:只有一個接口與外部相連的網絡,如一個PPP可視為一個stub網絡
骨干區域(Backbone Area):所有區域邊界路由器和它們之間的路由組成骨干區域.
自治系統外部路由(AS external route):指由非OSPF協議得到的路由,如BGP(邊界網關協議),RIP(Routing Information Protocol),系統的靜態配置路由等,系統的靜態路由是由配置得到的,其他協議的路由是通過引入操作得到的,外部路由的指定是由用戶決定的.
路由(route):指兩節點之間的連通路徑。
路由表(routing table):到每個目的地有路由,這樣的表叫路由表。
基本概念:
OSPF把整個網絡(Internet上的子網或其他類型的網)看成一個自治系統(AS)
每一個AS內若干個物理上相鄰的路由器(Router),網絡(Network)組成Area,這些Area內部一般是不相交的,它們劃分了整個AS。
如圖是一個典型的自治系統劃分的例子:
Rxx代表路由器,N*代表網絡,
1.R1,R2,R3,R4,N1組成區域1,R3,R4是區域邊界路由器(ABR)
2.R7,R8,R10,N2,N3組成區域2,R7,R10,R11是區域邊界路由器(ABR)
3.R9.R11,R12,N4組成區域3,R11是區域邊界路由器(ABR)
4.所有區域邊節點(R3,R4,R7,R10,R11)及R5,R6共同組成了骨干區域 .
網絡就像一個王國,這個王國可以分成b幾個區(area),現在我們來看看區域內的某一個人(你所在的機器root)是怎樣得到一張世界地圖(routing table)的。
首先,你得跟你周圍的人(同一網段如129.102)建立基本聯系。你大叫一聲“我在這!”(發HELLO報文),于是,周圍的人知道你的存在,他們也會大叫,這樣你知道周圍大概有哪些人,你與他們之間建立了鄰居(neighbor)關系,當然,他們之間也有鄰居關系。
在你們這一群人中,最有威望(Priority優先級)的人會被推薦為首領(Designated Router)首領與你之間是上下級關系(adjacency鄰接),它會與你建立單線聯系,而不許你與其它鄰居有過多交往,他會說:“那樣做的話,街上太擠了”。
你只好通過首領來知道更多的消息了,首先,你們繼續訪問 取消訪問互通消息,他告訴你他知道的所有地圖的地名,你也會告訴他你現知道的地名,當然上也許只有你一個點。(Database Description數據庫描述報文)
你發現地名表中有你缺少的或比你新的東西,你會問他要一份更詳細的資料,他發現你的地名表中有他需要的東西,他也會向你索求新資料。(Link State Request連接狀態請求報文)
當然,你們毫不猶豫地將一份詳細資料發送給對方。(Link State Update連接狀態升級報文)
收到地圖后,互相致謝表示收到了。(Link State Ack連接狀態響應報文)現在,你已經盡你所能得到一份地圖(Link State DataBase連接狀態數據庫),你去查找地圖把到所有地方的路挑一條最近(shortest path最短路)的,記為一張表格(routing table路由表),當然以后查這份表格就知道到目的地的一條最近的路了。地圖也要收好,萬一表格上的某條路不通了可以通過圖去找一條新的路。
其實跟你有聯系的,只是周圍一群人,外面的消息要通過首領來知道。因為你的地圖是跟首領的一致,我們假設你是首領,你要去畫一份世界地圖。
你命令所有手下向你通報消息,你可以知道你這一群人的任何一點點小動靜(event事件)。你手下還會有同時屬于兩群人的家伙(同一區內兩網段),他會告訴你另一群人的地圖,當然也會把你們這一群人的地圖泄露,(不過,無所謂啦)。這樣,整個區的地圖你知道了(對于不知道的那也沒辦法,我們盡力了)。
通過不停地交換地圖,現在,整個區的人都有同樣的地圖了,住在區邊境上的人義不容辭地把這個區的地圖(精確到每一群人)發送到別的區,把別的區信息發送進來。國王會把這些邊境的人命名為骨干(backbone area)。通過骨干人士的不懈努力,現在,整個國家的地圖你都了解得一清二楚了。
有些人“里通外國”(AS Boundary Router自治系統邊界,他們知道一些“出國”(AS External route自治系統外部路由)的路,當然他們會把這些秘密公之與眾(import 引入),通過信息的傳遞,現在,你已經有一張完整的“世界地圖”了。
OSPF是這樣標記最短的路的:對于某個目的地,首先,考慮是否有同一區內部到目的地的路(intra area區域內),如果有,則在其中取一條離你最近的(花費最小),寫進你的表格中,這個目的地可能是到本群體某個人也可能是到其他群體的,對于經過其他區域的路由,你會不予考慮,跟自己人(同區域)打交道總比與外人(其他區域)打交道好;如果沒有本區的路,你只好通過別的區域了(區域間),你只要在地圖上找最近的就是了;如果你發現目的地在國外,你也只能先把它標記到你的表格上,期待什么時候王國擴張到那,你就可以把它標記到國內地圖上了。
OSPF就是這樣,給你一份“世界地圖”,并且在上面標記了最短的路,如此而已罷了。
1.2. 背景介紹
TCP/IP協議中,尋找一臺計算機到另一臺計算機的路由是很重要的.
1.要判斷是否能找到路
2.找到路后找一條短的路(花費時間最小)
3.在找路時不能循環
4.最好還應該能動態處理路由變化,如:接口的UP或DOWN,時間花費的變化,
IETF(Internet Engineering Task Force)于1988年提出的OSPF是一個基于鏈路狀態的動態路由協議,
思路如下:在自治系統中每一臺運行OSPF的由器收集各自的接口/鄰接信息稱為鏈路狀態,通過Flooding算法在整個系統廣播自己的鏈路狀態,使得在整個系統內部維護一個同步的鏈路狀態數據庫,根據這一數據庫,路由器計算出以自己為根,其它網絡節點為葉的一根最短的路徑樹,從而計算出自己到達系統內部可達的最佳路由]。
OSPF是一類Interior Gateway Protocol(內部網關協議IGP),它處理在一個自治系統中,路由器的網絡的路由表信息。
1.3. 術語和基本概念
OSPF路由協議術語:
OSPF路由協議:Open Shortest Path First 最短路徑優先協議
路由器(router):第三層的IP包交換機,以前在IP文獻中也叫做網關
自治系統(autonomy system):一群路由器通過相同的路由協議來交換路由信息,
縮寫為AS區域(area):自治系統的劃分單元,一個自治系統可以劃分為多個區域.
區域 ID(area ID):自治系統內區域的32-bit標識
內部網關協議(internal gateway protocol):屬于一個自治系統的路由器上運行的路
由協議,縮寫為IGP,每一個自治系統有一個單獨的IGP,不同的自治系統可能
運行不同的IGP。OSPF是內部網關協議的一種
路由器的ID(router ID):一個32位的標號對每個運行OSPF的路由器,在自治系
唯一的網絡(network):在這種意義下,是IP網絡/子網/超網,可能是標記了多重復合IP
地址的子網,我們把它們看成是分離的網絡,點到點的物理網絡是個特例,它們
只是被當作簡單的網,不管對它們怎樣指定IP號。
網絡掩碼(network mask):一個32位的數指示IP網絡的IP地址范圍,以十六進
制數顯示,例如一個C類網的掩碼是0xfffff00,在文字上寫成255.255.255.0。
點到點網絡(point to point network):由一對路由器簡單組成的網絡,例如一個
56Kb的串口線的連接
廣播網:網絡支持許多(兩個以上)的路由器。都有能力將地址信息發送到所有連
接的路由器上(廣播)鄰居路由器被OSPF的hello協議動態地發現,OSPF使這種
廣播能力能得到更大的應用,如果它存在,它上的每一對路由器都假定能和對方
直接相連,以太網是一個廣播網的例子。
非廣播網:網絡支持許多(兩個以上)路由器,但沒有廣播能力,鄰結點也是通過OSPF hello報文來維持,但是由于設有廣播能力一些鄰居需要靠配置來發現,在鄰居間,OSPF協議報文也是互相傳送的,X.25網是一個例子。
OSPF可以在兩種非廣播網上運行,一種是非廣播多重訪問,(NBMA)它類似于OSPF在廣播網上的操作,第二種類型叫點到多點,可看為多個點到點的連接的集合。非廣播網類型的判別依靠于對網絡的操作模式。
接口(interface):一個路由器與它連接的一個網絡 的連接稱為接口,一個接口有它的狀態信息,可以通過底層協議或是路由協議本身來得到。每個接口有一個唯一一個IP地址和掩碼(除非是不標號的點到點連接),一個接口有時也指一個連接。
鄰居路由器(neighbor):兩臺路由器有接口連向共同的網絡,鄰居關系通過OSPF hello協議被維持(通常是動態的)。
鄰接(adjacency):為交換路由而在鄰居間建立的關系,不是每對鄰居都成都為鄰接的。
連接狀態傳送(Link State Advertise):描述本地路由器或網絡的數據單元 對路由器來說,它描述了路由器的接口狀態和鄰接狀態,第一個連接狀態傳送會發送到整個路由領域,所有的連接狀態傳送組成了協議的連接狀態數據庫,這在全局范圍內使用,縮寫為LSA
連接狀態數據庫(Link State DataBase):所有連接狀態傳送組成了連接狀態數據庫.
Stub網絡:只有一個接口與外部相連的網絡,如一個PPP可視為一個stub網絡
骨干區域(Backbone Area):所有區域邊界路由器和它們之間的路由組成骨干區域.
自治系統外部路由(AS external route):指由非OSPF協議得到的路由,如BGP(邊界網關協議),RIP(Routing Information Protocol),系統的靜態配置路由等,系統的靜態路由是由配置得到的,其他協議的路由是通過引入操作得到的,外部路由的指定是由用戶決定的.
路由(route):指兩節點之間的連通路徑。
路由表(routing table):到每個目的地有路由,這樣的表叫路由表。
基本概念:
OSPF把整個網絡(Internet上的子網或其他類型的網)看成一個自治系統(AS)
每一個AS內若干個物理上相鄰的路由器(Router),網絡(Network)組成Area,這些Area內部一般是不相交的,它們劃分了整個AS。
如圖是一個典型的自治系統劃分的例子:
Rxx代表路由器,N*代表網絡,
1.R1,R2,R3,R4,N1組成區域1,R3,R4是區域邊界路由器(ABR)
2.R7,R8,R10,N2,N3組成區域2,R7,R10,R11是區域邊界路由器(ABR)
3.R9.R11,R12,N4組成區域3,R11是區域邊界路由器(ABR)
4.所有區域邊節點(R3,R4,R7,R10,R11)及R5,R6共同組成了骨干區域 .
評論
查看更多