BGP協議最佳路徑選擇算法揭秘

BGP協議是壹個路徑矢量路由協議,也就是說,它的工作就是在自主系統間交換路由信息,以便發現訪問互聯網某處數據的最有效路徑。每個BGP路由器通過鄰居聲名與周邊的壹個或多個路由器連接。壹旦建立了鄰居關系,這些BGP路由器之間就會相互交換路由信息。據我最近壹次統計,整個互聯網上有大約12.5萬個路由信息,因此要配備壹個強大的路由器才能將所有BGP路由信息接收下來。

什麽是 BGP 最佳路徑選擇算法?
由於整個互聯網的BGP路由表有超過20萬個路由,同時壹個BGP路由器可能從多個來源收到多份的路由表,因此肯定會有壹種方法可以比較不同的BGP路由表,並從中選擇最佳的路由方案。這種方法就是BGP最佳路徑選擇算法。可能妳會註意到,CiscoBGP路由器會將應用權重(weight)作為路由表的第壹標準,而其它品牌的路由器則不是這樣。Cisco的官方BGP最佳路徑選擇算法文檔中詳細列明了所參考的各項標準。接下來我會列出每種標準並給出解釋和範例。默認情況下,BGP最佳路徑都是基於最短自治系統(AS)的原理得出的。不過很多時候,諸如weight,localpreference以及MED這樣的標準都是網絡管理員自行設定的。

接下來我們就按照BGP選擇最佳路徑的參考順序將這幾項標準介紹壹下:
#1 Weight —權重是Cisco為本地路由器設定的自定義參數,並不隨路由器更新而變化。如果指向某壹IP地址的路徑有多條(這很常見),那麽BGP會尋找權重最高的路徑。設定權重的參考因素很多,包括鄰居命令,as-path訪問列表,或者路由鏡像等。
  #2 Local Preference — 本地出口優先級參數會告知AS哪條路徑具有本地優先,數值越高優先級越高。默認為100。比如:
  bgp default local-preference 150
  #3 Network or Aggregate—這個參數會選擇本地發起的網絡或聚合作為路徑。將特定的路徑加入路由中,會讓路由更有效率,同時也節省了網絡空間。更多有關聚合的信息,可以參考Cisco的文章“UnderstandingRouteAggregation in BGP.”
  #4 Shortest AS_PATH — BGP 只有在weight, localpreference和locallyoriginated相當接近的時候才使用這個參數。
  #5 Lowest origin type — 這個參數處理Interior Gateway Protocol(IGP)協議的優先級低於 Exterior Gateway Protocol (EGP)協議。
  #6 Lowest multi-exit discriminator (MED) — 較低的MED值要優於較高的MED值。
  #7 eBGP over iBGP — 類似於#5, BGP AS Path 更傾向 eBGP 而不是 iBGP。
  #8 Lowest IGP metric — 這個參數傾向於采用最低IGP作為BGP下壹跳。
  #9 Multiple paths — 這個參數決定是否要在路由表中裝入多個路徑。可以參考 BGPMultipath獲取更多信息。
  #10 External paths — 當所有路徑都為外部路徑時,選擇首先接收到的路徑(較老的路徑)。)
  #11 Lowest router ID — 選擇來自具有最低路由器ID的BGP路由器的路徑。
  #12 Minimum cluster list — 如果多個路徑的originator或路由器ID相同,選擇cluster列表長度最短的路徑。
  #13 Lowest neighbor address — 這是指最低鄰居地址傳來的路徑。
  有些命令需要不斷的用到BGP 參數,它們是show ip bgp 和 show ipbgpsummary。實際上,我更喜歡給這兩個命令創建別名,以便能更快捷的使用它們(參考我的文章《用Cisco命令別名更有效的輸入命令》)。這些命令可以讓妳快速獲取BGP以及與路由器的關系。下面是使用show ip bgp命令後的情況範例:
  RTA# show ip bgpg
  BGP table version is 14, local router ID is 203.250.15.10
  Status codes: s suppressed, d damped, h history, * valid,>best, i -internal
  Origin codes: i – IGP, e – EGP, ? – incomplete
  Network Next Hop Metric LocPrf Weight Path
  *>i128.213.0.0 128.213.63.2 0 200 0 200 i
  > 192.208.10.0 192.208.10.5 0 300 0 300 i
  *>i200.200.0.0/16 128.213.63.2 200 0 200 400i
  >i203.250.13.0 203.250.13.41 0 100 0 i
  *>i203.250.14.0 203.250.13.41 0 100 0 i
  *> 203.250.15.0 0.0.0.0 0 32768 i
  帶星號的是BGP最佳路徑選擇算法選出的最佳路徑。
  總結:
  不論妳是使用BGP的網管,還是只是為了CCIE或CCNP考試學習BGP的學員,懂得這方面的知識都是非常有益的。正如上面看到的,使用參數和命令行的方式,確實可以快速實現所需功能。