实验3:OpenFlow协议分析实践

一. 实验目的


  1. 搭建下图所示拓扑,完成相关 IP 配置,并实现主机与主机之间的 IP 通信。用抓包软件获取控制器与交换机之间的通信数据。
#!/usr/bin/env python

from mininet.net import Mininet
from mininet.node import Controller, RemoteController, OVSController
from mininet.node import CPULimitedHost, Host, Node
from mininet.node import OVSKernelSwitch, UserSwitch
from mininet.node import IVSSwitch
from mininet.cli import CLI
from mininet.log import setLogLevel, info
from mininet.link import TCLink, Intf
from subprocess import call

def myNetwork():

    net = Mininet( topo=None,
                   build=False,
                   ipBase='192.168.0.0/24')

    info( '*** Adding controller\n' )
    c0=net.addController(name='c0',
                      controller=Controller,
                      protocol='tcp',
                      port=6633)

    info( '*** Add switches\n')
    s1 = net.addSwitch('s1', cls=OVSKernelSwitch)
    s2 = net.addSwitch('s2', cls=OVSKernelSwitch)

    info( '*** Add hosts\n')
    h1 = net.addHost('h1', cls=Host, ip='192.168.0.101', defaultRoute=None)
    h2 = net.addHost('h2', cls=Host, ip='192.168.0.102', defaultRoute=None)
    h3 = net.addHost('h3', cls=Host, ip='192.168.0.103', defaultRoute=None)
    h4 = net.addHost('h4', cls=Host, ip='192.168.0.104', defaultRoute=None)

    info( '*** Add links\n')
    net.addLink(h1, s1)
    net.addLink(h3, s1)
    net.addLink(s1, s2)
    net.addLink(s2, h2)
    net.addLink(s2, h4)

    info( '*** Starting network\n')
    net.build()
    info( '*** Starting controllers\n')
    for controller in net.controllers:
        controller.start()

    info( '*** Starting switches\n')
    net.get('s1').start([c0])
    net.get('s2').start([c0])


    CLI(net)
    net.stop()

if __name__ == '__main__':
    setLogLevel( 'info' )
    myNetwork()

(1) hello包
表示含义:控制器6633端口 发送“我最高能支持OpenFlow1.0”信息给交换机57180端口

于是双方建立连接,并使用OpenFlow1.0

(2)Feature_Request
表示含义:控制器6633端口发送“我需要你的特征信息”信息给交换机的57180端口

(3)Set_Conig
表示含义:控制器6633端口发送信息“请按照我给你的Flag和Max_Bytes of Packet进行配置"信息给交换机的57180端口

(4) Port_Status

当交换机端口发生变化时,告知控制器相应的端口状态。

(5) Features Reply

表示含义:交换机57180端口发送“这是我的特征信息,请查收”信息给控制器的6633端口

(6) Packet_in

交换机查找流表,发现没有匹配条目时
有匹配条目但是对应的action是OUTPUT=CONTROLLER时
表示含义:交换机57180端口发送“有数据包进入,请指示”信息给控制器的6633端口

(7) Flow_mod

分析抓取的flow_mod数据包,控制器通过6633端口向交换机57180端口、交换机57180端口下发流表项,指导数据的转发处理

(8) Packet_out

表示含义:控制器6633端口发送“请按照我给你的action进行处理”信息给交换机的57180端口

回答问题:交换机与控制器建立通信时是使用TCP协议还是UDP协议?

TCP协议

posted on 2022-10-05 22:02  zzzxxzxzxzxzxz  阅读(79)  评论(0编辑  收藏  举报

导航