实验3:OpenFlow协议分析实践
一、实验目的
- 能够运用 wireshark 对 OpenFlow 协议数据交互过程进行抓包;
- 能够借助包解析工具,分析与解释 OpenFlow协议的数据包交互过程与机制。
二、实验环境
- 下载虚拟机软件Oracle VisualBox;
- 在虚拟机中安装Ubuntu 20.04 Desktop amd64,并完整安装Mininet;
三、实验要求
(一)基本要求
- 搭建下图所示拓扑,完成相关 IP 配置,并实现主机与主机之间的 IP 通信。用抓包软件获取控制器与交换机之间的通信数据包。
主机 | IP地址 |
---|---|
h1 | 192.168.0.101/24 |
h2 | 192.168.0.102/24 |
h3 | 192.168.0.103/24 |
h4 | 192.168.0.104/24 |
- 查看抓包结果,分析OpenFlow协议中交换机与控制器的消息交互过程,画出相关交互图或流程图。
-
- 回答问题:交换机与控制器建立通信时是使用TCP协议还是UDP协议?答:
TCP协议建立通信
(二)进阶要求
- 将抓包结果对照OpenFlow源码,了解OpenFlow主要消息类型对应的数据结构定义。
(三)实验报告
- 请用Markdown排版,
- 将(一)中导出的拓扑文件存入目录:/home/用户名/学号/lab3/;
- (一)只需要提交导入拓扑文件、wireshark抓包的结果截图和附图说明,其余文字请勿赘述;
- (二)不做必须要求,有完成的同学请提交相关文字分析说明。
- 个人总结:这一次实验难度适中,在抓包过程中出现没有Hello包的情况,在询问同学查找资料后,得知导致这种情况可能是因为打开拓扑运行过早,需要在wireshark中获取全部包界面后再对对拓扑RUN以便获取HELLO包,通过最近的学习对SDN又有了进一步的了解和学习,实践和知识的理解相互结合才能融会贯通,通过OpenFlow 协议数据交互,对报文的交互过程有了一定的了解,相信通过不断的学习和巩固,个人的知识和能力会更上一层楼。