一、Several Utilities

OpenFlow Tutorial VM 中预装了一些OpenFlow特性的工具和一般通用网络的工具。

1、Openflow Controller:处于Openflow南向接口上层。Controller又称NOS(Network Operating Systems),是SDN架构中十分重要的一层,用于支持控制逻辑在高层制定的策略的基础上配置网络。在后面会NOX、Beacon等平台上编写自己的Controller。

2、OpenFlow Switch:处于OpenFlow接口之下。

3、ovs-ofctl:命令行工具,用于快捷地发送Openflow消息,在查看交换机端口、查看流量统计和手动插入流表项方面十分有用。

4、wireshark。

5、iperf:通用命令行工具,用于测试单个TCP连接的速度。

6、mininet:网络仿真平台,用于搭建OpenFlow网络(controller,switches,hosts and links)。

7、cbench:性能测试工具。

二、搭建网络:

1、拓扑:

在SSH terminal中输入:   $ sudo mn --topo single,3 --mac --switch ovsk --controller remote

通过该命令,在mininet中建立起如图拓扑,并使其MAC地址与IP地址相同(用IP地址主机号设置MAC地址),并使用远端Controller。

三、Ping Test

1、在mininet提示符后输入:h1 ping -c3 h2

发现不能ping通。因为此时switch的流表是空的,ping命令的数据包到达switch时发现没有匹配项,需要用packet-in数据包上传至controller,由于controller决定其处理策略,而此时switch还没有连接到controller,故无法ping通。

2、使用ovs-ofctl手动添加流表项:

再打开一个SSH terminal,同样连接到VM,在其中输入命令:

# sudo ovs-ofctl add-flow s1 in_port=1,actions=output:2

# sudo ovs-ofctl add-flow s1 in_port=2,actions=output:1

查看switch流表项,输入命令:# sudo ovs-ofctl dump-flows s1

3、再次使用ping命令,能够ping通:

四、启动Wireshark:

在SSH terminal中输入:sudo wireshark & 启动。(确保主机系统GUI与ubuntu14.04兼容,ubuntu18.04不能正常使用)

五、启动控制器并抓包:

1、在wireshark中选择loopback接口为监听接口,并在过滤器中输入过滤规则:"openflow_v1"。

2、在SSH terminal中输入命令:sudo controller ptcp:  启动一个类似具有学习能力的交换机的controller。

各种数据包的类型如下:

六、观察ping命令的openflow数据包:

1、首先修改过滤规则,忽略掉用于保持Switch和Controller之间连接活性的echo-request/reply数据包。

从上图中可以得到过滤规则:openflow_v1 && openflow_1_0.type!=2 && openflow_1_0.type!=3

2、为了观察ping命令的openflow数据包,需删掉之前添加的流表项,之外还建议删掉host上的ARP cache。

在SSH terminal中输入:sudo ovs-ofctl del-flow s1

在mininet terminal中输入:

  h1 ip -s -s neigh flush all

  h2 ip -s -s neigh flush all

3、再次执行ping命令,发现可以ping通,且Wireshark捕获到相关openflow数据包。

No.623:一个ARP请求在流表中失配,产生一个目的地址为广播地址的Packet-In数据包。

No.624:由ARP miss产生的一个广播Packet-Out数据包,用于查找相应IP地址主机的MAC地址。

No.626:当相应IP地址接收到广播Packet-Out数据包时,向源MAC地址返回一个点播告诉其自己的MAC地址。

No.627:Controller一个Flow-Mod数据包给Switch,在Switch的流表中添加一个特定数据流的流表项。

No.628:ping命令发送ICMP(Internet Control Message Protocol)数据包,Switch流表中无匹配项,因而通过Packet-In数据包上传至Controller。

No.629:将流表项添加到switch的流表中。

No.630:从h2返回的ICMP数据包,Switch流表中无匹配项,因而通过Packet-In数据包上传至Controller。

No.631:将流表项添加到switch的流表中。

其后数据包从序号和时间戳来看,应该不是本次ping命令产生的数据包。

ping命令发送三次ICMP数据包,后两次因为switch的流表中已有相应匹配项,因而不会产生Openflow数据包。

一定时间后流表项会超时作废。

该实验中这种使用Openflow的方式称为reactive mode(响应模式);还有一种在数据包到达switch之前就下发流表项的模式称为proactive mode(主动模式),这种模式可以避免swtich到controller之间的一个往返时间延迟(round-trip time)和添加流表项的时间。

    

图中各种数据包类型如下图解释:

七、Benchmark Controller w/iperf (衡量、检测)

1、iperf是用来检测两个主机间速度的命令行工具。

该命令在一个主机上运行一个iperf TCP server,在另一个主机上运行一个iperf client,建立连接以后双方相互发送大量数据包(blast packets)并报告结果。

2、与user-space switch比较:

关闭之前的拓扑,新建使用user-space switch的拓扑:

输入命令:sudo mn --topo single,3 --controller remote --switch user

运行iperf:

可以发送数据传输的速率慢了很多。因为使用user-space switch时,数据包在每一跳都需要从user-space进入kernel-space,再从kernel-space回到user-space,而不是在kernel-space中进行传输。user-space switch更容易修改,但是慢很多。

OpenFlow_tutorial_3_Learn_Development_Tools的更多相关文章

随机推荐

  1. XMU C语言程序设计实践(2)

    任务一:颠倒的世界 小明最近突然喜欢倒着写字,写出来的句子全是颠倒的,也就是把一句话里的字符全都逆序写,譬如“I Love This Game!”,他就偏偏要写成“!emaG sihT evoL I” ...

  2. (转)Javascript中console.log()用法

    原文地址应该是这个吧:http://my.oschina.net/junn/blog/142728 注意:必须要提前打开IE的开发者模式才能看到输入 否则就会报错. IE下可以这个判断: if (co ...

  3. Linux 常用命令十二 top

    一.top命令 top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器. top显示系统当前的进程和其他状况,是一个动态显示过程,即可以 ...

  4. 如何管理第三方接口token过期时间

    背景: 随着微服务的盛行,做开发时不可避免的要涉及第三方接口,安全起见,这些接口都会需要一个token参数.而token一般都会有一个过期时间,比如2小时或者30分钟.那么如何在自己的应用中存储并管理 ...

  5. Java 反射机制详解(上)

    一.什么是反射 JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意方法和属性:这种动态获取信息以及动态调用对象方法的功能称为java ...

  6. 2017 JUST Programming Contest 3.0 I. Move Between Numbers

    I. Move Between Numbers time limit per test 2.0 s memory limit per test 256 MB input standard input ...

  7. 贪心 Codeforces Round #109 (Div. 2) B. Combination

    题目传送门 /* 贪心:按照能选的个数和点数降序排序,当条件不符合就break,水题啊! */ #include <cstdio> #include <algorithm> # ...

  8. how-to-fix-fs-re-evaluating-native-module-sources-is-not-supported-graceful

    http://stackoverflow.com/questions/37346512/how-to-fix-fs-re-evaluating-native-module-sources-is-not ...

  9. MyEclipse去除不必要的validation

    MyEclipse在构建项目时去除不必要的Valication可以加快构建速度. 操作: Window->Perferences->MyEclipse->Validation 在Va ...

  10. rabbitmq实践笔记(一):安装、配置与使用初探

    引言: 对于一个大型的软件系统来说,会有很多的组件.模块及不同的子系统一起协同工作,模块之间的通信需要一个可靠的通信管道来保证 ,通信管道需要解决解决很多问题,比如: 1)信息的发送者和接收者如何维持 ...