当前位置: 首页 > news >正文

计算机网络第4章-通用转发和SDN

引子:

在前面,我们将基于目的地转发的特征总结为两个步骤:

查找目的IP地址(匹配),然后将分组发送到有特定输出端口的交换结构(“动作”)。

但是这种转发特征会带来许多问题,列如很多中间盒都有自己特殊的硬件、软件和管理界面,这对

于网络管理员来说是大麻烦,为此人们设计出了一种新的转发结构:“通用转发”。并且将使用通用

转发的中间盒叫作:“分组交换机。”

通用转发

在通用转发中,一张“匹配加动作表”讲我们的基于目的地的转发表一般化了。

下图是一个位于每台分组交换机中的一张匹配加动作表,该表由远程控制器计算。

在这里,我们有必要了解一下OpenFlow标准,这是一个SDN革命的先驱标准。

我们主要探讨OpenFlow1.0.

其中,匹配加动作转发表在OpenFlow中称为:流表”。

1.首部字段值的集合

首部字段值的集合,在进入流表后会进行匹配。匹配不上的分组会被丢弃。

2.计数器集合

当分组与流表项匹配上后,就会更新计数器。

这些计数器可以包括已经与该表项匹配的分组数量。

当分组匹配流表项时所采取的动作集合

这些动作可能将分组转发到给定的输出端口,丢弃该分组、复制该分组和将它们发送到多个输出端

口,或重写所选的首部字段。

值得注意的是,流表本质上是一个API,通过这种抽象每台分组交换机的行为能够被编程,类似

的,网络范围的行为也能够被编程。

匹配

下图是一个匹配示意图:

上图显示了11个分组首部字段和入端口IP,该IP能够被OpenFlow1.0中的匹配加动作所匹配。

OpenFlow的匹配抽象允许对上面的三个层次协议的首部所选择的字段进行匹配。

需要注意的是:

OpenFlow也可以有通配符,例如在流表中IP地址128.119.*.*将匹配其地址的前16比特为128.119的

任何数据报所对应的地址字段。

同时,流表也具有优先权,优先权越高,选定的匹配和对应的动作将是其中有最高优先权的那个。

动作

对于流表项,其实都有零个或多个动作列表,这些动作决定了以用于流表项匹配的分组的处理。

但是如果以后有多个动作,它们在表中按以下规定的次序执行:

1.转发

一个入分组可以转发到一个特定的物理输出端口,广播到所有端口,或通过所选的端口集合进行多播。

该分组也可能被封装并发送到用于该设备的远程控制器,该控制器则可能对该分组采取某些动作,

也可能忽略这个分组。

2.丢弃

没有动作的流表项表明某个匹配的分组应当被丢弃。

3.修改字段

在分组被转发到所选的输出端口之前,分组首部10个字段中的值可以重写。

也就是上图(图4-29中显示的除IP协议字段外的所有第二、三、四层字段)中的值可以重写。

匹配加动作操作中的OpenFlow例子

下图是一个使用OpenFlow标准的网络图:

第一例子:简单转发

现在我们假定一个转发行为:“来自h5或h6发往h3或h4的分组从s3转发到s1,然后从s1转发到

S2(完全避免使用s2和s3之间的链路。)”

对于上面例子,在s1中的流表项将是下图:

同时s3中也会有一个流表项:

最后,还需要在s2中也有一个流表项用来完成例子,使得从s1到达的数据报转发到它们的目的主机

h3或者h4:

第二个例子:负载均衡

下面我们来考虑一个负载均衡的例子,其中来自h3发往10.1.*.*的数据报经过s1和s2之间的直接链

路转发,与此同时来自h4发送10.1.*.*的数据报也经过s2和s3转发,注意的这种行为将不能通过基

于IP的目的地转发取得,因此,此时的s2中的流表项如下图所示:

在s1中需要流表项将从s2收到的数据报转发到h1或h2,在s3中需要流表项将接口4上从s2收到的数

据报经过接口3转发到s1。

第三个例子:充当防火墙

例如s2仅希望接收来自与s3相连的主机所发送的流量:

如果在s2的流表中没有其他表项,仅有来自10.3.*.*的流量将被转发到与s2相连的主机。

相关文章:

  • http中的Content-Type类型
  • hdlbits系列verilog解答(always块条件语句)-37
  • Nginx 请求拷贝、请求镜像
  • C语言 || volatile
  • 为什么HTTP用得很好的,开始普及HTTPS呢?
  • react:swr接口缓存
  • [BROADCASTING]tensor的扩散机制
  • Process Monitor 进程监控器 exe监控 windows程序监控
  • gitlab 设置 分支只读
  • Git 安全警告修复手册:解决 `fatal: detected dubious ownership in repository at ` 问题 ️
  • SpringBoot加载测试类属性和配置说明
  • git 提交代码,但是有些文件没有上传
  • 【论文阅读】PSDF Fusion:用于动态 3D 数据融合和场景重建的概率符号距离函数
  • Kotlin基础数据类型和运算符
  • Python的计算性能优化
  • 【Redis学习笔记】2018-06-28 redis命令源码学习1
  • 【个人向】《HTTP图解》阅后小结
  • 30秒的PHP代码片段(1)数组 - Array
  • Docker: 容器互访的三种方式
  • Electron入门介绍
  • GitUp, 你不可错过的秀外慧中的git工具
  • go语言学习初探(一)
  • IOS评论框不贴底(ios12新bug)
  • Iterator 和 for...of 循环
  • opencv python Meanshift 和 Camshift
  • 工作中总结前端开发流程--vue项目
  • 开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
  • 每天一个设计模式之命令模式
  • 如何合理的规划jvm性能调优
  • 写代码的正确姿势
  • LevelDB 入门 —— 全面了解 LevelDB 的功能特性
  • mysql 慢查询分析工具:pt-query-digest 在mac 上的安装使用 ...
  • ​ ​Redis(五)主从复制:主从模式介绍、配置、拓扑(一主一从结构、一主多从结构、树形主从结构)、原理(复制过程、​​​​​​​数据同步psync)、总结
  • (六) ES6 新特性 —— 迭代器(iterator)
  • (一)spring cloud微服务分布式云架构 - Spring Cloud简介
  • (原+转)Ubuntu16.04软件中心闪退及wifi消失
  • (转)Oracle存储过程编写经验和优化措施
  • (转)为C# Windows服务添加安装程序
  • (转载)hibernate缓存
  • *Django中的Ajax 纯js的书写样式1
  • .dat文件写入byte类型数组_用Python从Abaqus导出txt、dat数据
  • .NET Core 控制台程序读 appsettings.json 、注依赖、配日志、设 IOptions
  • .NET Framework 4.6.2改进了WPF和安全性
  • .Net mvc总结
  • .net遍历html中全部的中文,ASP.NET中遍历页面的所有button控件
  • .secret勒索病毒数据恢复|金蝶、用友、管家婆、OA、速达、ERP等软件数据库恢复
  • /boot 内存空间不够
  • @data注解_SpringBoot 使用WebSocket打造在线聊天室(基于注解)
  • @Service注解让spring找到你的Service bean
  • [ 常用工具篇 ] AntSword 蚁剑安装及使用详解
  • [C#]扩展方法
  • [caffe(二)]Python加载训练caffe模型并进行测试1
  • [CVPR2021]Birds of a Feather: Capturing Avian Shape Models from Images
  • [Design Pattern] 工厂方法模式
  • [Eclipse] 详细设置护眼背景色和字体颜色并导出