Lab 6:网络层路由协议模拟与观察
Lab6 Part1:分布式距离路由算法
一、实验原理
首先让我们回顾课堂上所讲的距离向量算法:

Dx(y)表示从x到y的最低开销估计值。节点x维护距离向量 Dx = [Dx(y): y є N ],包含了x到网络中所有目的地y的开销估计值。对于节点x,其维护了到每个邻居的直接开销c(x,v) 和每个邻居的距离向量,即对每个邻居v,节点x保存Dv = [Dv(y): y є N ]。
算法核心思路: 每个节点都将自己的距离向量估计值传递给邻居,定时或者距离向量有变化时,让对方去重新计算距离向量。 当x从邻居收到距离向量时,采用B-F equation更新它自己的距离向量。
B-F equation:Dx(y) ← minv{c(x,v) + Dv(y)} for each node y ∊ N
Dx(y)估计值最终收敛于实际的最小代价值dx(y)。
下面提供了一个具体的例子供同学们理解算法:

二、实验任务
为此网络实现分布式异步距离向量路由算法:

1. 具体任务
对每个节点编程完成初始化与更新功能,这些功能将在为作业提供的模拟环境中异步执行。
以0号节点为例: rtinit0( ) 和 rtupdate0 ( )
rtinit0( )
在模拟开始将调用一次该函数,rtinit0( ) 无参数
它应当初始化节点0中的距离表,以反映出到达节点1、2和3的直接开销分别为1、3和7
它应向其直接连接的邻居(在本情况中为节点1、2和3)发送它到所有其他网络节点的最低开销路径的开销信息
通过调用函数tolayer2( ),这种最低开销信息在一个路由选择更新分组中被发送给相邻节点
rtupdate0(struct rtpkt* rcvdpkt)
当节点0收到一个由其直接相连邻居之一发给它的路由选择分组时,调用该函数,参数*rcvdpkt是一个指向接收分组的指针
rtupdate0( )从其他节点i接收的路由选择更新分组中,包含了节点i到所有其他网络节点的当前最短路径开销值
rtupdate0( )使用这些收到的值来更新其自身的距离表
如果它自己到另外节点的最低开销由于此更新而发生改变的话,则节点0通过发送一个路由选择分组来通知其直接相连邻居这种最低开销的变化,仅有直接相连的节点才交换路由选择分组
2. 代码分析与软件接口
关键结构体:
dt0 为节点 0 的距离表
cost[i][j] 为节点 0 通过邻居 j 到达节点 i 的当前开销估计值
Tips:
tolayer2(struct rtpkt pkt2send) 传入参数是结构体,不是结构体的指针
printdt0(struct distance_table *dtptr) 打印节点 0 的距离表
3. 网络环境仿真
prog3.c中#define LINKCHANGES 设置为0
rtinit0( ), rtinit1( ), rtinit2( ), rtinit3( ), rtupdate0( ), rtupdate1( ), rtupdate2( ), rtupdate3( ) 将路由分组发送到传输介质中,分组将会按序无丢失地达到目的地
只有直连的节点间可以通信,时延为常数
gcc prog3.c node0.c node1.c node2.c node3.c (C语言版本)
编译完成后,运行代码时要求提供Tracing值
Tracing=1/2 打印模拟过程中的有用信息 (分组和计时器)
Tracing>2会输出所有调试信息
三、作业要求
为路由器分别编写node0.c, node1.c, node2.c, node3.c完成指定功能,在其中一个.c文件中自定义的全局变量不可被其他.c文件访问
执行rtinit( ) 时,输出 :
调用时间(通过全局变量clocktime 获取)
当前距离表的内容
打印通告对象与信息
执行rtupdate( )时,输出 :
调用时间(通过全局变量clocktime 获取)
接收到的分组的发送方
当前距离表的内容
若距离表更新,打印通告对象与信息;若距离表未更新,打印未更新
所需提交内容:
提交所有源文件 (C代码)
提交Trace=2的输出结果,output.pdf,将每个节点最终的距离表高亮,并给出每个节点到其他节点的最小开销值
按照实验要求完成实验,提交实验报告,并提供必要的截图
参考资料:
https://media.pearsoncmg.com/aw/aw_kurose_network_3/labs/lab6/lab6.html (C/JAVA code)
http://www.cse.psu.edu/~gxc27/teach/514/lab2/python/ (Python Code)
Lab6 Part2:RIP和OSPF路由协议观察
一、实验目的
回顾网络层数据平面IP地址、子网、掩码等概念与知识,加强对网络层控制平面基于距离向量和基于链路状态的路由协议的理解。
学会初步使用华为eNSP网络仿真模拟器,掌握网络拓扑搭建和配置IP等技能。
通过网络仿真平台,观察两种路由协议RIP和OSPF的报文,能够指出路由表中的表项是由哪些具体的报文产生的,并比较RIP和OSPF两种路由协议的异同点。
二、实验原理
首先让我们回顾课堂上所将的RIP协议和OSPF协议:
RIP: Routing Information Protocol [RFC 1723]
经典的距离向量路由算法
原理部分可以参考Lab6 Part1的实验原理
OSPF: Open Shortest Path First [RFC 2328]
链路状态路由
IS-IS protocol (ISO standard, not RFC standard) 本质上与OSPF相同
原理:Dijkstra算法,计算从一个节点(“源”)到所有其他节点的最小代价路径,算法的伪代码如下:
下面提供一个实例供同学们理解:

三、实验任务
本次实验将在华为eNSP网络仿真模拟器上进行。华为eNSP模拟器 (Enterprise Network Simulation Platform) 是华为官方推出的一款强大的图形化网络仿真工具平台,eNSP模拟器主要对企业网路由器、交换机等设备进行软件仿真,从而得以呈现真实设备部署实景,并且支持大型网络模拟,让使用者有机会在没有真实设备的情况下也能够开展实验测试、学习网络技术。
本次实验需要同学们在华为eNSP模拟器上搭建网络拓扑、配置子网、配置路由协议并在路由器端口进行抓包,观察RIP和OSPF协议的报文,分析两种协议的异同点。
1. 环境搭建与软件安装
所需要的安装包:https://pan.baidu.com/s/1XnNnxuqU_A01zNwL-daKYg
提取码:4B45
安装步骤参考:https://blog.csdn.net/m0_74451345/article/details/135967195
需要windows环境,Mac电脑的同学请使用机房的电脑。
win11上安装virtual box可能会出现的问题及解决方案:https://blog.csdn.net/wenzhongxiang/article/details/133188587
2.实验任务
任务一:RIP协议报文观察
(1)网络拓扑搭建
搭建好如下的网络拓扑:

eNSP搭建网络拓扑采用拖拽式,路由器选择 AR2220,连线选择 Auto。
完成网络拓扑搭建后记得启动所有设备。
(2)IP配置
PC的基础配置:


路由器配置:
AR1配置:
interface GigabitEthernet 0/0/0 :进入某个指定端口
ip address 192.168.1.254 24:配置端口IP地址,最后 24 为掩码长度
AR2配置:
AR3配置:
(3)路由协议配置
RIP路由协议配置,下面以AR1为例,AR2和AR3请同学自行完成:
network指令:在RIP中通告自己所在的网络
配置完请使用ping指令测试:PC1 ping PC2

(4)查看路由器内IP路由表
(5)端口抓包
右键点击交换机选择 “数据抓包”

第一部分:完成以下任务并回答问题
按照要求搭建拓扑,完成相关PC与路由器的配置,配置成功 PC1 应能 ping PC2,截图。并在图中指出网络中共有几个子网,每个子网的地址及掩码是什么?
查看各个路由器的中的IP路由表,截图并用红色的框标识出RIP协议产生的路由表项。
在各个路由器端口进行抓包,观察RIP协议报文,截图举例说明报文各字段的含义。并说明路由器中的IP路由表中的RIP路由表项是如何由RIP协议报文中的距离向量计算得出的,举一个例子即可。
RIP协议中,距离向量的传递是在邻居之间,还是距离向量会直接传播到全网?传递的距离向量是完整的距离向量吗?截图举例说明。
(6)变化网络拓扑
按照下图修改网络拓扑:

第二部分:完成以下任务并回答问题
按照要求搭建新的拓扑,完成相关路由器的配置(AR1和AR3的新端口的配置、RIP路由协议的配置)。并在图中指出网络中共有几个子网,每个子网的IP及掩码是什么?
观察各个路由器的IP路由表变化,截图AR1和AR3的IP路由表;并在各个路由器端口进行抓包,说明在改变网络拓扑后RIP报文中距离向量的变化,以及该变化如何影响IP路由表,截图并举例说明。
任务二:OSPF协议报文观察
网络拓扑搭建(使用旧的网络拓扑)、IP配置、路由表查看、端口抓包与任务一相同,此处不再赘述。
OSPF路由协议配置
完成以下任务并回答问题:
按照要求搭建拓扑,完成相关PC与路由器的配置,配置成功PC1应能ping PC2,截图。
查看各个路由器的中的IP路由表,截图并用红色的框标识出OSPF协议产生的路由表项。
在各个路由器端口进行抓包,观察OSPF协议中LS Update Packet,截图举例说明Router-LSA和Network-LSA各自的作用与区别。并说明路由器中的IP路由表中的OSPF路由表项是如何由OSPF协议报文中的LSA计算得出的,截图并说明。参考资料:OSPF报文格式解析
OSPF协议中的LSA信息传递是在邻居间交换还是在全网传递,截图并说明。
Last updated