实验2:Open vSwitch虚拟交换机实践
一、实验目的
1.能够对Open vSwitch进行基本操作;
2.能够通过命令行终端使用OVS命令操作Open vSwitch交换机,管理流表;
3.能够通过Mininet的Python代码运行OVS命令,控制网络拓扑中的Open vSwitch交换机
二、实验环境
1.下载虚拟机软件Oracle VisualBox 或 VMware;
2.在虚拟机中安装Ubuntu 20.04 Desktop amd64,并完整安装Mininet;
三、实验要求
(一)基本要求
1.创建OVS交换机,并以ovs-switchxxx命名,其中xxx为本人在选课班级中的序号,例如ovs-switch001, ovs-switch088等。在创建的交换机上增加端口p0和p1,设置p0的端口号为100,p1的端口号为101,类型均为internal;为了避免网络接口上的地址和本机已有网络地址冲突,需要创建虚拟网络空间(参考命令netns)ns0和ns1,分别将p0和p1移入,并分别配置p0和p1端口的ip地址为190.168.0.100、192.168.0.101,子网掩码为255.255.255.0;最后测试p0和p1的连通性。
①创建ovs交换机,以ovs-switch078命名
②创建端口p0,设置编号为100,类型internal,因为之前界面没了重开,故这里显示已创建
sudo ovs-vsctl add-br ovs-switch033
③创建端口p1,设置编号为101,类型internal
④创建一个虚拟网络空间ns0,把p0接口移入网络空间ns0,并配置IP地址为 192.168.0.100
sudo ip netns add ns0
sudo ip link set p0 netns ns0
sudo ip netns exec ns0 ip addr add 192.168.0.100/24 dev p0
sudo ip netns exec ns0 ifconfig p0 promisc up
不知道为什么前面输入的指令缺了
⑤创建一个虚拟网络空间ns1,把p1接口移入网络空间ns1,并配置IP地址为 192.168.0.101
sudo ip netns add ns1
sudo ip link set p1 netns ns1
sudo ip netns exec ns1 ip addr add 192.168.0.101/24 dev p1
sudo ip netns exec ns1 ifconfig p1 promisc up
⑥输入命令sudo ovs-vsctl show查看ovs交换机状态
⑦输入sudo ip netns exec ns0 ping 192.168.0.101和sudo ip netns exec ns1 ping 192.168.0.100进行p0和p1连通性测试
2.使用Mininet搭建的SDN拓扑,如下图所示,要求支持OpenFlow 1.3协议,主机名、交换机名以及端口对应正确。
①输入sudo python3 miniedit.py打开Mininet可视化工具,搭建拓扑:
②将拓扑保存在/home/ubuntu/102192104/lab2/下
③用文本编辑器打开test.py,修改链接端口
④运行test.py
3.通过命令行终端输入“ovs-ofctl”命令,直接在s1和s2上添加流表,划分出所要求的VLAN。
VLAN_ID Hosts
0 h1 h3
1 h2 h4
①添加s1流表
②添加s2流表
4.主机连通性要求:
h1 – h3互通
h2 – h4互通
其余主机不通
输入sudo wireshark,mininet命令行输入pingall,抓取s1的3号端口上所传送的包
①抓取h1发往h3的包(VLAN标记0已标上)
②抓取h2发往h4的包(VLAN标记1已标上)
四.个人总结
本次实验总体上比上次熟练了很多,主要也少了安装软件的繁琐,由于虚拟机是linux系统,而我的电脑是window系统,
很多指令无法在外部打完粘贴进去,而在mininet环境下一旦输入错误又得重新开始输入。这次的大部分操作指令长度都挺
长的,导致我浪费了不少时间。
在创建虚拟网络空间的时候报错,重新创建又显示已经存在了,使用sudo rm -rf / run/netns删除虚拟网路络空间也
不行,突然意识到之前备份虚拟机的必要性,重开又弄了一次。
通过一次次的作业,相对来说熟练度慢慢提高了,希望下次在写博客上能有所精进。