Added a new topology and a tool to set controllers on all OVS bridges remotely.
Change-Id: I875fbc8bec844ac30d1d8bccff0db45ad7c4ac71
Showing
2 changed files
with
165 additions
and
0 deletions
tools/test/bin/onos-set-controllers
0 → 100755
| 1 | +#!/bin/bash | ||
| 2 | +# ----------------------------------------------------------------------------- | ||
| 3 | +# Sets controllers on all OVS bridges on the mininet machine. | ||
| 4 | +# ----------------------------------------------------------------------------- | ||
| 5 | + | ||
| 6 | +controllers="" | ||
| 7 | + | ||
| 8 | +for node in $ONOS_INSTANCES; do | ||
| 9 | + controllers="$controllers tcp:$node:${OF_PORT:-6633}" | ||
| 10 | +done | ||
| 11 | + | ||
| 12 | +ssh ${ONOS_USER:-sdn}@$OCN " | ||
| 13 | + sudo ovs-vsctl list-br | while read br; do | ||
| 14 | + echo \$br: $controllers | ||
| 15 | + sudo ovs-vsctl set-controller \$br $controllers | ||
| 16 | + done | ||
| 17 | +" |
tools/test/topos/newFuncTopo.py
0 → 100644
| 1 | +#!/usr/bin/python | ||
| 2 | + | ||
| 3 | +""" | ||
| 4 | +Custom topology for Mininet | ||
| 5 | +""" | ||
| 6 | +from mininet.topo import Topo | ||
| 7 | +from mininet.net import Mininet | ||
| 8 | +from mininet.node import Host, RemoteController | ||
| 9 | +from mininet.node import Node | ||
| 10 | +from mininet.node import CPULimitedHost | ||
| 11 | +from mininet.link import TCLink | ||
| 12 | +from mininet.cli import CLI | ||
| 13 | +from mininet.log import setLogLevel | ||
| 14 | +from mininet.util import dumpNodeConnections | ||
| 15 | +from mininet.node import ( UserSwitch, OVSSwitch, IVSSwitch ) | ||
| 16 | + | ||
| 17 | +class VLANHost( Host ): | ||
| 18 | + def config( self, vlan=100, **params ): | ||
| 19 | + r = super( Host, self ).config( **params ) | ||
| 20 | + intf = self.defaultIntf() | ||
| 21 | + self.cmd( 'ifconfig %s inet 0' % intf ) | ||
| 22 | + self.cmd( 'vconfig add %s %d' % ( intf, vlan ) ) | ||
| 23 | + self.cmd( 'ifconfig %s.%d inet %s' % ( intf, vlan, params['ip'] ) ) | ||
| 24 | + newName = '%s.%d' % ( intf, vlan ) | ||
| 25 | + intf.name = newName | ||
| 26 | + self.nameToIntf[ newName ] = intf | ||
| 27 | + return r | ||
| 28 | + | ||
| 29 | +class IPv6Host( Host ): | ||
| 30 | + def config( self, v6Addr='1000:1/64', **params ): | ||
| 31 | + r = super( Host, self ).config( **params ) | ||
| 32 | + intf = self.defaultIntf() | ||
| 33 | + self.cmd( 'ifconfig %s inet 0' % intf ) | ||
| 34 | + self.cmd( 'ip -6 addr add %s dev %s' % ( v6Addr, intf ) ) | ||
| 35 | + return r | ||
| 36 | + | ||
| 37 | +class dualStackHost( Host ): | ||
| 38 | + def config( self, v6Addr='2000:1/64', **params ): | ||
| 39 | + r = super( Host, self ).config( **params ) | ||
| 40 | + intf = self.defaultIntf() | ||
| 41 | + self.cmd( 'ip -6 addr add %s dev %s' % ( v6Addr, intf ) ) | ||
| 42 | + return r | ||
| 43 | + | ||
| 44 | +class MyTopo( Topo ): | ||
| 45 | + | ||
| 46 | + def __init__( self ): | ||
| 47 | + # Initialize topology | ||
| 48 | + Topo.__init__( self ) | ||
| 49 | + # Switch S5 Hosts | ||
| 50 | + host1=self.addHost( 'h1', ip='10.1.0.2/24' ) | ||
| 51 | + host2=self.addHost( 'h2', cls=IPv6Host, v6Addr='1000::2/64' ) | ||
| 52 | + host3=self.addHost( 'h3', ip='10.1.0.3/24', cls=dualStackHost, v6Addr='2000::2/64' ) | ||
| 53 | + #VLAN hosts | ||
| 54 | + host4=self.addHost( 'h4', ip='100.1.0.2/24', cls=VLANHost, vlan=100 ) | ||
| 55 | + host5=self.addHost( 'h5', ip='200.1.0.2/24', cls=VLANHost, vlan=200 ) | ||
| 56 | + #VPN-1 and VPN-2 Hosts | ||
| 57 | + host6=self.addHost( 'h6', ip='11.1.0.2/24' ) | ||
| 58 | + host7=self.addHost( 'h7', ip='12.1.0.2/24' ) | ||
| 59 | + #Multicast Sender | ||
| 60 | + host8=self.addHost( 'h8', ip='10.1.0.4/24' ) | ||
| 61 | + | ||
| 62 | + # Switch S6 Hosts | ||
| 63 | + host9=self.addHost( 'h9', ip='10.1.0.5/24' ) | ||
| 64 | + host10=self.addHost( 'h10', cls=IPv6Host, v6Addr='1000::3/64' ) | ||
| 65 | + host11=self.addHost( 'h11', ip='10.1.0.6/24', cls=dualStackHost, v6Addr='2000::3/64' ) | ||
| 66 | + #VLAN hosts | ||
| 67 | + host12=self.addHost( 'h12', ip='100.1.0.3/24', cls=VLANHost, vlan=100 ) | ||
| 68 | + host13=self.addHost( 'h13', ip='200.1.0.3/24', cls=VLANHost, vlan=200 ) | ||
| 69 | + #VPN-1 and VPN-2 Hosts | ||
| 70 | + host14=self.addHost( 'h14', ip='11.1.0.3/24' ) | ||
| 71 | + host15=self.addHost( 'h15', ip='12.1.0.3/24' ) | ||
| 72 | + #Multicast Receiver | ||
| 73 | + host16=self.addHost( 'h16', ip='10.1.0.7/24' ) | ||
| 74 | + | ||
| 75 | + # Switch S7 Hosts | ||
| 76 | + host17=self.addHost( 'h17', ip='10.1.0.8/24' ) | ||
| 77 | + host18=self.addHost( 'h18', cls=IPv6Host, v6Addr='1000::4/64' ) | ||
| 78 | + host19=self.addHost( 'h19', ip='10.1.0.9/24', cls=dualStackHost, v6Addr='2000::4/64' ) | ||
| 79 | + #VLAN hosts | ||
| 80 | + host20=self.addHost( 'h20', ip='100.1.0.4/24', cls=VLANHost, vlan=100 ) | ||
| 81 | + host21=self.addHost( 'h21', ip='200.1.0.4/24', cls=VLANHost, vlan=200 ) | ||
| 82 | + #VPN-1 and VPN-2 Hosts | ||
| 83 | + host22=self.addHost( 'h22', ip='11.1.0.4/24' ) | ||
| 84 | + host23=self.addHost( 'h23', ip='12.1.0.4/24' ) | ||
| 85 | + #Multicast Receiver | ||
| 86 | + host24=self.addHost( 'h24', ip='10.1.0.10/24' ) | ||
| 87 | + | ||
| 88 | + s1 = self.addSwitch( 's1' ) | ||
| 89 | + s2 = self.addSwitch( 's2' ) | ||
| 90 | + s3 = self.addSwitch( 's3' ) | ||
| 91 | + s4 = self.addSwitch( 's4' ) | ||
| 92 | + s5 = self.addSwitch( 's5' ) | ||
| 93 | + s6 = self.addSwitch( 's6' ) | ||
| 94 | + s7 = self.addSwitch( 's7' ) | ||
| 95 | + | ||
| 96 | + self.addLink(s5,host1) | ||
| 97 | + self.addLink(s5,host2) | ||
| 98 | + self.addLink(s5,host3) | ||
| 99 | + self.addLink(s5,host4) | ||
| 100 | + self.addLink(s5,host5) | ||
| 101 | + self.addLink(s5,host6) | ||
| 102 | + self.addLink(s5,host7) | ||
| 103 | + self.addLink(s5,host8) | ||
| 104 | + | ||
| 105 | + self.addLink(s6,host9) | ||
| 106 | + self.addLink(s6,host10) | ||
| 107 | + self.addLink(s6,host11) | ||
| 108 | + self.addLink(s6,host12) | ||
| 109 | + self.addLink(s6,host13) | ||
| 110 | + self.addLink(s6,host14) | ||
| 111 | + self.addLink(s6,host15) | ||
| 112 | + self.addLink(s6,host16) | ||
| 113 | + | ||
| 114 | + self.addLink(s7,host17) | ||
| 115 | + self.addLink(s7,host18) | ||
| 116 | + self.addLink(s7,host19) | ||
| 117 | + self.addLink(s7,host20) | ||
| 118 | + self.addLink(s7,host21) | ||
| 119 | + self.addLink(s7,host22) | ||
| 120 | + self.addLink(s7,host23) | ||
| 121 | + self.addLink(s7,host24) | ||
| 122 | + | ||
| 123 | + self.addLink(s1,s2) | ||
| 124 | + self.addLink(s1,s3) | ||
| 125 | + self.addLink(s1,s4) | ||
| 126 | + self.addLink(s1,s5) | ||
| 127 | + self.addLink(s2,s3) | ||
| 128 | + self.addLink(s2,s5) | ||
| 129 | + self.addLink(s2,s6) | ||
| 130 | + self.addLink(s3,s4) | ||
| 131 | + self.addLink(s3,s6) | ||
| 132 | + self.addLink(s4,s7) | ||
| 133 | + topos = { 'mytopo': ( lambda: MyTopo() ) } | ||
| 134 | + | ||
| 135 | +# HERE THE CODE DEFINITION OF THE TOPOLOGY ENDS | ||
| 136 | + | ||
| 137 | +def setupNetwork(): | ||
| 138 | + "Create network" | ||
| 139 | + topo = MyTopo() | ||
| 140 | + network = Mininet(topo=topo, autoSetMacs=True, controller=None) | ||
| 141 | + network.start() | ||
| 142 | + CLI( network ) | ||
| 143 | + network.stop() | ||
| 144 | + | ||
| 145 | +if __name__ == '__main__': | ||
| 146 | + setLogLevel('info') | ||
| 147 | + #setLogLevel('debug') | ||
| 148 | + setupNetwork() |
-
Please register or login to post a comment