计算机网络——网络层之路由选择协议

2023-10-31

参考链接

  1. CSKAOYAN.COM

路由选择协议

自治系统AS

由于:1) 因特网规模很大;2)许多单位不想让外界知道自己的路由选择协议,但还想连入因特网,于是产生了自治系统AS

在单一的技术管理下的一组路由器,而这些路由器使用一种AS内部的路由选择协议和共同的度量以确定分组在该AS内的路由,同时还使用一种AS之间的路由协议以确定在AS之间的路由

一个AS内的所有网络都属于一个行政单位来管辖,一个自治系统的所有路由器在本自治系统内都必须连通
在这里插入图片描述

内部网关协议

RIP协议

概念

RIP是一种分布式的基于距离向量的路由选择协议,是因特网的协议标准,最大优点是简单

RIP协议要求网络中每一个路由器都维护从它自己到其他每一个目的网络的唯一最佳距离记录(即一组距离)

距离:通常称为“跳数”,即从源端口到目的端口所经过的路由器个数,经过一个路由器跳+1。特别地,从一路由器到直接连接的网络距离为1。RIP允许一条路由最多只能包含15个路由器,因此距离为16表示网络不可达

RIP协议只适用于小互联网

如何交换信息
  1. 仅和相邻路由器交换信息

  2. 路由器交换的信息是自己的路由表

  3. 每30秒交换一次路由信息,然后路由器根据新信息更新路由表。若超过180s没收到邻居路由器的通告,则判定邻居没了,并更新自己路由表

  4. 路由器刚开始工作时,只知道直接链接的网络的距离(距离为1),接着每一个路由器也只和数目非常有限的相邻路由器交换并更新路由信息。经过若干次更新后,所有路由器最终都会知道到达本自治系统任何一个网络的最短距离和下一跳路由器的地址,即“收敛”

RIP协议的报文格式

RIP是应用层协议,使用UDP传送数据

一个RIP报文最多可包括25个路由,如超过,必须再用一个RIP报文传送
在这里插入图片描述

RIP的特点

当网络出现故障时,要经过比较长的时间(例如数分钟)才能将此信息传送到所有的路由器,“慢收敛”

OSPF协议

概念

开放最短路径优先OSPF协议:“开放”标明OSPF协议不是受一家厂商控制,而是公开发表的:“最短路径优先”是因为使用了Dijkstra提出的最短路径算法SPF

OSPF最主要的特征就是使用分布式的链路状态协议

OSPF的特点
  1. 使用洪泛法向自治系统内所有路由器发送信息,即路由器通过输出端口向所有相邻路的由器发送信息,而每一个相邻路由器又再次将此信息发往其所有的相邻路由器。(广播)

  2. 发送的信息就是与本路由器相邻的所有路由器的链路状态(本路由器和哪些路由器相邻,以及该链路的度量/代价——费用、距离、时延、带宽等)

  3. 只有当链路状态发生变化时,路由器才向所有路由器洪泛发送此信息

  4. 最后,所有路由器都能建立一个链路状态数据库,即全网拓扑图

OSPF算法流程
  1. 每个路由器发现它的邻居节点【HELLO问候分组】,并了解邻居节点的网络地址
  2. 设置到它的每个邻居的成本度量metric
  3. 构造【DD数据库描述分组】,向邻站给出自己的链路状态数据库中的所有链路状态项目的摘要信息
  4. 如果DD分组中的摘要信息自己都有,则邻站不做处理;如果有没有的或者是更新的,则发送【LSR链路状态请求分组】请求自己没有的和比自己更新的信息
  5. 收到邻站的LSR分组后,发送【LSU链路状态更新分组】进行更新
  6. 更新完毕后,邻站返回一个【LSAck链路状态确认分组】进行确认

只要一个路由器的链路状态发生变化:
5. 洪泛发送【LSU链路状态更新分组】进行更新
6. 更新完毕后,其他站返回一个【LSAck链路状态确认分组】进行确认
7. 使用Dijkstra根据自己的链路状态数据库构造到其他节点间的最短路径

OSPF的区域

为了使OSPF能够用于规模很大的网络,OSPF将一个自治系统再划分为若干个更小的范围,叫做区域

每一个区域都有一个32位的区域标识符(用点分十进制表示)

区域也不能太大,在一个区域内的路由器最好不要超过200个
在这里插入图片描述

OSPF分组

OSPF直接用IP数据报传送
在这里插入图片描述

OSPF的其他特点
  1. 每隔30min,要刷新一次数据库中的链路状态
  2. 由于一个路由器的链路状态只涉及到与相邻路由器的连通状态,因而与整个互联网的规模并无直接关系。因此,当互联网规模很大时,OSPF协议要比距离向量协议RIP好得多
  3. OSPF不存在坏消息传的慢的问题,它的收敛速度很快

外部网关协议

BGP协议

  1. 与其他AS的邻站BGP发言人交换信息

  2. 交换的网络可达性的信息,即要到达某个网络所要经过的一系列AS

  3. 发生变化更新有变化的部分

在这里插入图片描述

BGP协议交换信息的过程

BGP所交换的网络可达性的信息就是要到达某个网络所要经过的一系列AS。当BGP发言人互相交换了网络可达性的信息后,各BGP发言人就根据所采用的策略从收到的路由信息中找出到达个AS的较好路由

BGP协议报文格式

BGP是应用层协议,借助TCP传送

一个BGP发言人与其他自治系统中的BGP发言人要交换路由信息,就要先建立TCP链接,即通过TCP传送,然后在此连接上交换BGP报文以建立BGP会话(session),利用BGP会话交换路由信息
在这里插入图片描述

BGP协议的特点
  1. BGP支持CIDR,因此BGP的路由表也就应当包括目的网络前缀、下一跳路由器,以及到达该网络所要经过的各个自治系统序列

  2. 在BGP刚刚运行时,BGP的邻站是交换整个的BGP路由表。但以后只需要在发生变化时更新有变化的部分。这样做节省网络带宽和减少路由器的处理开销都有好处

BGP-4的四种报文
  1. OPEN(打开)报文:用来与相邻的另一个BGP发言人建立关系,并认证发送方

  2. UPDATE(更新)报文:通告新路径或撤销原路径

  3. KEEPALIVE(保活)报文:在无UPDATE时,周期性证实邻站的连通性;也作为OPEN的确认

  4. NOTIFICATION(通知)报文:报告先前报文的差错;也被用于关闭连接

三种路由协议比较

  1. RIP是一种分布式的基于距离向量的内部网关路由选择协议,通过广播UDP报文来交换路由信息

  2. OSPF是一个内部网关协议,要交换的信息量较大,应使报文的长度尽量短,所以不使用传输层协议(如UDP或TCP),而是直接采用IP

  3. BGP是一个外部网关协议,在不同的自治系统之间交换路由信息,由于网络环境复杂,需要保证可靠传输,所以采用TCP

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

计算机网络——网络层之路由选择协议 的相关文章

  • string.h文件中函数的详细用法

    常用 函数如下 strlen求字符串长度 strcmp比较2个字符串是否一样 strcat字符串连接操作 strcpy字符串拷贝操作 strncpy字符串拷贝操作 前n个字符 strncpy字符串拷贝操作 前n个字符 strchr 查询子串
  • STM32开发——串口通讯(第2篇)——WIFI(Esp8266)

    目录 1 ESP8266 作为设备 2 ESP8266作为服务器 注意 1 在中断中一般不直接在中断服务函数里处理数据 而是在收到数据后直接丢给队列 再处理数据 2 在中断服务函数里尽量减少使用延时函数及打印函数 1 ESP8266 作为设
  • ansible踩坑——环境变量问题

    问题现象 使用ansible启动远程服务器的node服务 环境变量未被加载 本地测试打印环境变量为空 定位原因 1 环境变量问题 首先ansible使用的是ssh的方式下发命令 为no login shell的方式登陆 在ubuntu的配置
  • C++ std::function的使用方法(c++11)

    std function是C函数指针的升级版 使C的面向过程与C 面向对象有了较大的区分 function在使用时需要包含头文件 include

随机推荐