CS 144 check6: buiding an IP router

Lecture Notes

Exercises

路由器的任务是根据路由表转发接收到的数据报:路由表是一系列规则,用于指导路由器针对任何给定的数据报应如何进行转发。

  • 发送出什么接口。
  • 下一跳的IP地址。

这个check的工作是实现一个路由器,它可以为任何给定的数据报解决上面这两件事。

代码实现上,需要配置一个Router类,可以实现:

  • 跟踪路由表(转发规则或路由的列表)
  • 转发它接收到的每个数据报:
    • 到正确的下一跳
    • 在正确的输出网络接口上。

一条路由是一条"匹配-动作"规则:它告诉路由器,如果一个数据报的目的地是特定网络(即一组IP地址范围),并且该路由被选为最具体的匹配路由,那么路由器应该将该数据报转发到特定接口上的特定下一跳。

匹配部分: 数据报是否发往这个网络?route_prefix(路由前缀)和prefix_length(前缀长度)共同指定了一个可能包含数据报目的地的IP地址范围(即网络)。route_prefix是一个32位的数值IP地址,而prefix_length是一个介于032(包括)之间的数字,表示route_prefix中多少个最高有效位是有效的。例如,为了表示通往"18.47.0.0/16"网络的路由(这匹配任何前两个字节为18和47的32位IP地址),route_prefix将是305070080(即18 × 2²⁴ + 47 × 2¹⁶),prefix_length16。任何发往"18.47.x.y"的数据报都会匹配。

动作部分: 如果路由匹配并且被选中,应该执行什么操作。如果路由器直接连接到所讨论的网络,next_hop(下一跳)将是一个空的可选项。在这种情况下,next_hop就是数据报的目的地址。但如果路由器通过其他路由器连接到所讨论的网络,next_hop将包含路径上下一个路由器的IP地址。接口编号给出了路由器应使用哪个 NetworkInterface 来发送数据报给next_hop。你可以通过 interface(interface_num) 方法访问此接口。

在路由器测试中使用的模拟测试网络见下图。

参考:

  1. CS 144
  2. CS144 | Winter 2024, Lab 0~7 记录(已开源)
相关推荐
夜月yeyue5 小时前
KCP 与 UDP 可靠传输
linux·网络·单片机·网络协议·udp·php
一个向上的运维者5 小时前
Docker 自定义网络中容器无法通过宿主机 IP 访问服务的完整排障记录
网络·tcp/ip·docker
WIZnet5 小时前
W55RP20-EVB-MKR MicroPython 实战(14):MQTT 协议与 OneNET 平台对接
单片机·网络协议·wiznet
utf8mb4安全女神5 小时前
子网划分【概念+实操+理解】
运维·服务器·网络
GlobalSign数字证书6 小时前
中小企业的 SSL/TLS 证书管理,有更轻量的方案
数据库·网络协议·ssl
码语智行6 小时前
拦截器、接口限流、过滤器、防重发/幂等性功能说明
开发语言·网络·python
志栋智能6 小时前
超自动化安全:构建智能安全运营的神经系统
大数据·运维·网络·人工智能·安全·自动化
华普微HOPERF6 小时前
LoRa模块,如何通过卫星通信补齐地面网络的覆盖盲区?
网络·嵌入式硬件·模块·卫星通信
酉鬼女又兒7 小时前
零基础入门计算机网络:从基本概念到核心交换技术
开发语言·计算机网络·考研·职场和发展·php
键盘上的猫头鹰7 小时前
【Linux 基础教程(一)】概述、安装与网络配置:VMware + CentOS + NAT + XShell 远程连接
linux·网络·centos