中文版翻译得很难理解,这里总结一下。

1、BGP的任务

前面已经讲到了AS内的路由协议,比如OSPF,那么假如两个路由器不在同一个AS内呢?这就要用到BGP。

BGP的一个重要任务是不同AS间的路由,不过BGP也可以进行AS内的路由(后面也会提到)。

2、BGP中的前缀

BGP中的分组不会被路由到特定的IP,而是会路由到前缀(prefix)。这个前缀代表了一个或者一组子网。

前缀是CIDR化的,CIDR确保了前缀能唯一地确定一个子网或者子网组。

3、BGP中转发表的信息表示

一个路由器可能有多个接口,转发表需要的信息是子网+接口号。
前缀的形式可以是这样的:138.16.68/22(没错就是IP协议中的子网,不过我不清楚这是否是唯一的前缀形式)

具体的信息可能是(x,l),x代表前缀,l代表接口号。

4、BGP的作用

1)、使每个路由器都能路由器从临近AS获得可达性信息。

可达性信息(NLRI),也就是该路由器所有能抵达的子网前缀,这些子网前缀的顺序也包含着路径信息,形式如下:

该作用确保了网络的每一个路由器都能得知其中每一个子网的存在。

2)、使路由器能获得到每个可达前缀的最优路径。

BGP提供了确定路由的方法。

5、如何发布BGP路由信息

这一部分介绍这么一个问题:假如网络中增加了一个子网,网络中的其他部分是如何得知该子网的存在呢?


如图是3个AS,AS3包含一个子网,它的前缀是x。
每个路由器中都包括网关路由器和内部路由器。所谓网关路由器,指的是某个接口与其他AS中的路由器相连。图中的1c, 2a, 2c, 3a是网关路由器。

AS1和AS2如何得知前缀x的存在呢?

从AS的层面:

首先,AS3需要告知AS2 前缀x的可达信息,这里表示为AS3 x

AS2接着告诉AS1前缀x的可达信息,这里表示为AS2 AS3 x

通过以上过程,所有的AS(即其中的每个路由器)不仅得知了x 的存在,而且知道了x的路径。

从路由器的层面

发送接收信息的肯定是路由器而非自治系统。所以再从路由器层面重新考虑一下前面的传播过程:

在路由器之间是通过TCP连接传输BGP信息的。
在一个AS内部,路由器建立的是iBGP连接,在不同AS之间,路由器之间建立的是eBGP连接
注意:一个iBGP连接未必对应着一条物理链路,iBGP的连接是比较复杂的,但是一个eBGP一定对应着一条物理链路

发送方 接收方 BGP类型 BGP信息
3a 2c eBGP AS3 x
2c AS2中的每个路由器(包括2a) iBGP AS3 x
2a 1c eBGP AS2 AS3 x
1c AS1中的每个路由器 iBGP AS2 AS3 x

通过以上过程,所有的路由器都能得到x的可达信息。

不过,实际情况中,到达AS1的路径可能不是唯一的,这样到达AS1的x的可达信息也可能有区别,这样就需要选择更好的路由路线。

6、确定最佳路由


首先再介绍一些BGP中的术语:

路线:前缀+BGP属性叫做路由

什么是BGP属性呢?有两个比较重要的属性: AS-PATH和NEXT-HOP

AS-PATH是什么?就是该BGP信息传播时所经过的所有AS,比如在前面的AS2 AS3。这其实就确定了一条路由。路由器在接收BGP信息时,假如收到了当前AS的值则会拒收,以此来避免环路发生。

NEXT-HOP是什么?它是与当前AS-PATH中起始的路由器接口的IP地址。
在上图中,可以看到AS1直接相连的路由器是2a和3d,那么AS1中的路由器会接收到这样的BGP信息:

路由器2a的最左侧接口的IP地址:AS2 , AS3 : x
路由器3d的最左侧接口的IP地址:AS3: x

注意到NEXT-HOP的特点:

  • 它不属于当前AS
  • 当前当前AS一定与它所在的子网相连(是否与该接口相连呢?)

1)热土豆路由选择协议

思想:仅考虑将分组送出当前AS的开销。
在上例中,热土豆路由选择协议会选择一条到达NEXT-HOP开销最小的路线。

(建议把热土豆协议翻译成烫山芋协议。在该协议中,分组被视为烫手的山芋,赶紧扔到其他AS再说,至于之后分组怎么传播他就不管了,那是其它AS的事情)

注意,在热土豆选择协议中,在同一个AS的不同路由器上,即便是相同的前缀,也可能有不同的路由。

2)BGP的路由选择算法

BGP的路由选择算法比较复杂,但他用到了热土豆选择协议的一部分。

路由选择算法的输入是需要路由的前缀以及通往该前缀的所有路由。
(说白了就是要在这些已知路由中选择一个最好的)

而选择的步骤是这样的:

  • 1、一条路由会被加上本地偏好(local preference)的属性。前面提到过路由有AS-PATH和NEXT-HOP属性,现在有三个属性了。本地偏好属性可能是直接在路由上设置的,也可能是从相邻路由器中得到值。这个值根本上是由管理员制定的策略的决定的。具有最高本地偏好的路由将被选择。
  • 2、最高本地偏好的路由假如有多个,则选择AS-PATH最短的路线。假如没有设计其他规则的话,则使用距离向量算法来选择最优路径。(注意:使用距离向量算法时,代价是AS之间的跳数而非路由器之间的跳数
  • 3、假如本地偏好和AS-PATH筛选后仍有多个路由,则使用热土豆选择协议,即选择与NEXT-HOP最近的路由。
  • 4、如果还是有多条路由,则使用BGP选择器来选择(具体的书上也没说)

计算机网络-自顶向下方法 7th 5.4 BGP协议总结相关推荐

  1. 计算机网络自顶向下方法 第六章 链路层和局域网 6.3 多路访问链路和协议

    计算机网络自顶向下方法总结6.3多路访问链路和协议 目录 6.3 多路访问链路和协议 6.3.1 信道划分协议 6.3.2 随机接入协议 6.3.3 轮流协议 6.3.4 DOCSIS:用于电缆以太网 ...

  2. 《计算机网络—自顶向下方法》 Wireshark实验(二):HTTP协议分析

    HTTP 协议工作于客户端-服务端架构上.浏览器作为 HTTP 客户端通过 URL 向 HTTP 服务端即 WEB 服务器发送所有请求. WEB 服务器有:Apache服务器,IIS服务器(Inter ...

  3. 《计算机网络——自顶向下方法》学习笔记——网络层:数据平面

    计算机网络--网络层:数据平面 网络层:数据平面 网络层概述 转发和路由选择:数据平面和控制平面 网络服务模型 路由器工作原理 输入端口处理和基于目的地转发 交换 输出端口处理 何处出现排队 分组调度 ...

  4. 计算机网络自顶向下方法知识点整理(部分)

    1-2物理媒体 1.双绞铜线 由两根绝缘的铜线组成,以规则的螺旋状排列. 无屏蔽双绞线(UTP)10Mbps~10Gbps 最终作为高速LAN联网的主导性解决方案也常用于住宅因特网接入 2.同轴电缆 ...

  5. 计算机网络自顶向下方法,第7版—第1章习题

    原博客: 计算机网络自顶向下方法,第7版--习题解答 只在原文的基础上加了一点自己的答案,其他没变,有些数学公式复制失败,建议去看原博客. 本文包含了 *Computer Networking A T ...

  6. 《计算机网络 自顶向下方法》 第2章 应用层 Part1

    常见的应用层协议有哪些?  HTTP(HyperText Transfer  Protocol):超文本传输协议 FTP(File Transfer Protocol):文件传输协议 SMTP(Sim ...

  7. 计算机网络自顶向下方法(二)——应用层

    不作理想的巨人,行动的矮子 文章目录 写在前面 应用层协议原理 网络应用程序体系结构 客户-服务器(C/S)体系结构 对等体(P2P)体系结构 C/S和P2P体系结构的混合体 进程通信 分布式进程通信 ...

  8. 计算机网络-自顶向下方法-笔记【第3章-传输层】

    计算机网络-自顶向下方法-笔记[第3章-传输层] 学习的课程及图片来源:中科大郑烇.杨坚全套<计算机网络(自顶向下方法 第7版,James F.Kurose,Keith W.Ross)>课 ...

  9. 计算机网络自顶向下方法 第三章 运输层 3.4 可靠数据传输原理

    计算机网络自顶向下方法总结3.4可靠数据传输原理 目录 3.4 可靠数据传输原理 3.4.1 构造可带数据传输协议 3.4.2 流水线可靠数据传输协议 3.4.3 回退N步 3.4.4 选择重传 3. ...

最新文章

  1. 两虎相争将带来优质的互联网搜索服务 --- 我看Google归来!
  2. 如何避免APK文件的反向工程?
  3. play mysql_play framework 2.0 使用 mysql
  4. 华为鸿蒙harmonyos-面向全场,华为正式官宣鸿蒙手机版相约6月2日,EMUI官博更名为HarmonyOS...
  5. angularjs学习曲线
  6. mysql php教程,MySQL PHP语法
  7. CentOS 6.2编译安装Nginx1.2.0+MySQL5.5.25+PHP5.3.13
  8. JZOJ4742 单峰
  9. SharePoint 2010开发实例精选——通过客户端对象模型删除页面上的Web部件
  10. 后序遍历二叉树(迭代 vs 递归)
  11. android datepicker 监听,Android编程之DatePicker和TimePicke简单时间监听用法分析
  12. hdu1829 A Bug's Life
  13. 开启关闭Centos的自动更新
  14. java 如何反编译文件
  15. EzCad 二次开发 金橙子激光雕刻机c# 能显示预览图
  16. 计算机网络拓扑结构功能是,计算机网络拓扑结构
  17. Empty filename passed to function Cannot find proj.db
  18. C++C++ 编写GoFGoF设计模式里Lexi样例
  19. VO,PO,BO,QO, DAO ,POJO,的概念
  20. 【PyTorch】下载的预训练模型的保存位置(Windows)

热门文章

  1. 鬼怪出没不害怕,最怕秒杀404
  2. C语言 小游戏 电脑大概率获胜,用C语言实现简单的三子棋小游戏
  3. 转: android编译过程(流程图)
  4. 三维点云学习(3)4-Expectation-Maximization (EM)
  5. Python字典依据value排序
  6. java for语句(翻译自Java Tutorials)
  7. Microsoft JDBC Driver 4.0 for SQL Server
  8. ORM框架之Spring Data JPA(一)Hibernate实现JPA规范
  9. 【我的相册】2018.2.15-年夜饭
  10. Ubuntu Linux下通过TPM1.2芯片保护SSH私钥的安全