pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 1 | #!/usr/bin/python |
| 2 | |
| 3 | """ |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 4 | Copyright 2015 Open Networking Foundation ( ONF ) |
Jeremy Ronquillo | b27ce4c | 2017-07-17 12:41:28 -0700 | [diff] [blame] | 5 | |
| 6 | Please refer questions to either the onos test mailing list at <onos-test@onosproject.org>, |
| 7 | the System Testing Plans and Results wiki page at <https://wiki.onosproject.org/x/voMg>, |
| 8 | or the System Testing Guide page at <https://wiki.onosproject.org/x/WYQg> |
| 9 | |
| 10 | TestON is free software: you can redistribute it and/or modify |
| 11 | it under the terms of the GNU General Public License as published by |
| 12 | the Free Software Foundation, either version 2 of the License, or |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 13 | ( at your option ) any later version. |
Jeremy Ronquillo | b27ce4c | 2017-07-17 12:41:28 -0700 | [diff] [blame] | 14 | |
| 15 | TestON is distributed in the hope that it will be useful, |
| 16 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 17 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 18 | GNU General Public License for more details. |
| 19 | |
| 20 | You should have received a copy of the GNU General Public License |
| 21 | along with TestON. If not, see <http://www.gnu.org/licenses/>. |
| 22 | """ |
Jeremy Ronquillo | b27ce4c | 2017-07-17 12:41:28 -0700 | [diff] [blame] | 23 | """ |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 24 | Set up the SDN-IP topology as same as it on Internet2 |
| 25 | """ |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 26 | """ |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 27 | AS 64513, ( SDN AS ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 28 | AS 64514, reachable by 10.0.4.1 |
| 29 | AS 64515, reachable by 10.0.5.1 |
| 30 | AS 64516, reachable by 10.0.6.1 |
| 31 | """ |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 32 | from mininet.net import Mininet |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 33 | from mininet.log import setLogLevel, info |
| 34 | from mininet.cli import CLI |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 35 | from mininet.node import Host, RemoteController |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 36 | from mininet.topo import Topo |
| 37 | from mininet.util import quietRun |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 38 | |
| 39 | QUAGGA_DIR = '/usr/lib/quagga' |
| 40 | QUAGGA_RUN_DIR = '/usr/local/var/run/quagga' |
Jon Hall | fabd7e5 | 2016-04-19 19:20:59 -0700 | [diff] [blame] | 41 | QUAGGA_CONFIG_DIR = '~/OnosSystemTest/TestON/tests/USECASE/USECASE_SdnipFunction/dependencies/' |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 42 | numSw = 39 |
| 43 | |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 44 | |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 45 | class VLANHost( Host ): |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 46 | |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 47 | def config( self, vlan=100, intfName=None, **params ): |
| 48 | r = super( Host, self ).config( **params ) |
| 49 | intf = self.intf( intfName ) |
| 50 | self.cmd( 'ifconfig %s inet 0' % intf ) |
| 51 | self.cmd( 'vconfig add %s %d' % ( intf, vlan ) ) |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 52 | self.cmd( 'ifconfig %s.%d inet %s' % ( intf, vlan, params[ 'ip' ] ) ) |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 53 | newName = '%s.%d' % ( intf, vlan ) |
| 54 | intf.name = newName |
| 55 | self.nameToIntf[ newName ] = intf |
| 56 | return r |
| 57 | |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 58 | |
| 59 | class SDNTopo( Topo ): |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 60 | |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 61 | "SDN Topology" |
| 62 | |
| 63 | def __init__( self, *args, **kwargs ): |
| 64 | |
| 65 | Topo.__init__( self, *args, **kwargs ) |
| 66 | |
| 67 | # BGP peer hosts |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 68 | p64514 = self.addHost( 'p64514' ) |
| 69 | p64515 = self.addHost( 'p64515' ) |
| 70 | p64516 = self.addHost( 'p64516' ) |
| 71 | |
| 72 | p64517 = self.addHost( 'p64517', cls=VLANHost, vlan=20 ) |
| 73 | p64518 = self.addHost( 'p64518', cls=VLANHost, vlan=20 ) |
| 74 | p64519 = self.addHost( 'p64519', cls=VLANHost, vlan=10 ) |
| 75 | p64520 = self.addHost( 'p64520', cls=VLANHost, vlan=10 ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 76 | |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 77 | """ |
| 78 | sw1 = self.addSwitch( 'SEAT', dpid='00000000000000a1' ) |
| 79 | sw2 = self.addSwitch( 'PORT', dpid='00000000000000a2' ) |
| 80 | sw3 = self.addSwitch( 'SUNN', dpid='00000000000000a3' ) |
| 81 | sw4 = self.addSwitch( 'RENO', dpid='00000000000000a4' ) |
| 82 | sw5 = self.addSwitch( 'LOSA', dpid='00000000000000a5' ) |
| 83 | sw6 = self.addSwitch( 'MISS', dpid='00000000000000a6' ) |
| 84 | sw7 = self.addSwitch( 'LASV', dpid='00000000000000a7' ) |
| 85 | sw8 = self.addSwitch( 'SALT', dpid='00000000000000a8' ) |
| 86 | sw9 = self.addSwitch( 'PHOE', dpid='00000000000000a9' ) |
| 87 | sw10 = self.addSwitch( 'TUCS', dpid='0000000000000a10' ) |
| 88 | sw11 = self.addSwitch( 'DENV', dpid='0000000000000a11' ) |
| 89 | sw12 = self.addSwitch( 'ELPA', dpid='0000000000000a12' ) |
| 90 | sw13 = self.addSwitch( 'MINN', dpid='0000000000000a13' ) |
| 91 | sw14 = self.addSwitch( 'KANS', dpid='0000000000000a14' ) |
| 92 | sw15 = self.addSwitch( 'TULS', dpid='0000000000000a15' ) |
| 93 | sw16 = self.addSwitch( 'DALL', dpid='0000000000000a16' ) |
| 94 | sw17 = self.addSwitch( 'HOUH', dpid='0000000000000a17' ) |
| 95 | sw18 = self.addSwitch( 'COLU', dpid='0000000000000a18' ) |
| 96 | sw19 = self.addSwitch( 'JCSN', dpid='0000000000000a19' ) |
| 97 | sw20 = self.addSwitch( 'BATO', dpid='0000000000000a20' ) |
| 98 | sw21 = self.addSwitch( 'EQCH', dpid='0000000000000a21' ) |
| 99 | sw22 = self.addSwitch( 'STAR', dpid='0000000000000a22' ) |
| 100 | sw23 = self.addSwitch( 'CHIC', dpid='0000000000000a23' ) |
| 101 | sw24 = self.addSwitch( 'INDI', dpid='0000000000000a24' ) |
| 102 | sw25 = self.addSwitch( 'CINC', dpid='0000000000000a25' ) |
| 103 | sw26 = self.addSwitch( 'LOUI', dpid='0000000000000a26' ) |
| 104 | sw27 = self.addSwitch( 'ATLA', dpid='0000000000000a27' ) |
| 105 | sw28 = self.addSwitch( 'JACK', dpid='0000000000000a28' ) |
| 106 | sw29 = self.addSwitch( 'CLEV', dpid='0000000000000a29' ) |
| 107 | sw30 = self.addSwitch( 'PITT', dpid='0000000000000a30' ) |
| 108 | sw31 = self.addSwitch( 'ASHB', dpid='0000000000000a31' ) |
| 109 | sw32 = self.addSwitch( 'WASH', dpid='0000000000000a32' ) |
| 110 | sw33 = self.addSwitch( 'RALE', dpid='0000000000000a33' ) |
| 111 | sw34 = self.addSwitch( 'CHAR', dpid='0000000000000a34' ) |
| 112 | sw35 = self.addSwitch( 'ALBA', dpid='0000000000000a35' ) |
| 113 | sw36 = self.addSwitch( 'BOST', dpid='0000000000000a36' ) |
| 114 | sw37 = self.addSwitch( 'HART', dpid='0000000000000a37' ) |
| 115 | sw38 = self.addSwitch( 'NEWY', dpid='0000000000000a38' ) |
| 116 | sw39 = self.addSwitch( 'PHIL', dpid='0000000000000a39' ) |
| 117 | """ |
| 118 | sw1 = self.addSwitch( 'sw1', dpid='00000000000000a1' ) |
| 119 | sw2 = self.addSwitch( 'sw2', dpid='00000000000000a2' ) |
| 120 | sw3 = self.addSwitch( 'sw3', dpid='00000000000000a3' ) |
| 121 | sw4 = self.addSwitch( 'sw4', dpid='00000000000000a4' ) |
| 122 | sw5 = self.addSwitch( 'sw5', dpid='00000000000000a5' ) |
| 123 | sw6 = self.addSwitch( 'sw6', dpid='00000000000000a6' ) |
| 124 | sw7 = self.addSwitch( 'sw7', dpid='00000000000000a7' ) |
| 125 | sw8 = self.addSwitch( 'sw8', dpid='00000000000000a8' ) |
| 126 | sw9 = self.addSwitch( 'sw9', dpid='00000000000000a9' ) |
| 127 | sw10 = self.addSwitch( 'sw10', dpid='0000000000000a10' ) |
| 128 | sw11 = self.addSwitch( 'sw11', dpid='0000000000000a11' ) |
| 129 | sw12 = self.addSwitch( 'sw12', dpid='0000000000000a12' ) |
| 130 | sw13 = self.addSwitch( 'sw13', dpid='0000000000000a13' ) |
| 131 | sw14 = self.addSwitch( 'sw14', dpid='0000000000000a14' ) |
| 132 | sw15 = self.addSwitch( 'sw15', dpid='0000000000000a15' ) |
| 133 | sw16 = self.addSwitch( 'sw16', dpid='0000000000000a16' ) |
| 134 | sw17 = self.addSwitch( 'sw17', dpid='0000000000000a17' ) |
| 135 | sw18 = self.addSwitch( 'sw18', dpid='0000000000000a18' ) |
| 136 | sw19 = self.addSwitch( 'sw19', dpid='0000000000000a19' ) |
| 137 | sw20 = self.addSwitch( 'sw20', dpid='0000000000000a20' ) |
| 138 | sw21 = self.addSwitch( 'sw21', dpid='0000000000000a21' ) |
| 139 | sw22 = self.addSwitch( 'sw22', dpid='0000000000000a22' ) |
| 140 | sw23 = self.addSwitch( 'sw23', dpid='0000000000000a23' ) |
| 141 | sw24 = self.addSwitch( 'sw24', dpid='0000000000000a24' ) |
| 142 | sw25 = self.addSwitch( 'sw25', dpid='0000000000000a25' ) |
| 143 | sw26 = self.addSwitch( 'sw26', dpid='0000000000000a26' ) |
| 144 | sw27 = self.addSwitch( 'sw27', dpid='0000000000000a27' ) |
| 145 | sw28 = self.addSwitch( 'sw28', dpid='0000000000000a28' ) |
| 146 | sw29 = self.addSwitch( 'sw29', dpid='0000000000000a29' ) |
| 147 | sw30 = self.addSwitch( 'sw30', dpid='0000000000000a30' ) |
| 148 | sw31 = self.addSwitch( 'sw31', dpid='0000000000000a31' ) |
| 149 | sw32 = self.addSwitch( 'sw32', dpid='0000000000000a32' ) |
| 150 | sw33 = self.addSwitch( 'sw33', dpid='0000000000000a33' ) |
| 151 | sw34 = self.addSwitch( 'sw34', dpid='0000000000000a34' ) |
| 152 | sw35 = self.addSwitch( 'sw35', dpid='0000000000000a35' ) |
| 153 | sw36 = self.addSwitch( 'sw36', dpid='0000000000000a36' ) |
| 154 | sw37 = self.addSwitch( 'sw37', dpid='0000000000000a37' ) |
| 155 | sw38 = self.addSwitch( 'sw38', dpid='0000000000000a38' ) |
| 156 | sw39 = self.addSwitch( 'sw39', dpid='0000000000000a39' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 157 | |
| 158 | # Add a layer2 switch for control plane connectivity |
| 159 | # This switch isn't part of the SDN topology |
| 160 | # We'll use the ovs-controller to turn this into a learning switch |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 161 | swCtl100 = self.addSwitch( 'swCtl100', dpid='0000000000000100' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 162 | |
| 163 | # BGP speaker hosts |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 164 | spk1 = self.addHost( 'spk1' ) |
| 165 | spk2 = self.addHost( 'spk2', cls=VLANHost, vlan=20 ) |
| 166 | spk3 = self.addHost( 'spk3', cls=VLANHost, vlan=10 ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 167 | |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 168 | root = self.addHost( 'root', inNamespace=False, ip='0' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 169 | |
| 170 | # hosts behind each AS |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 171 | h64514 = self.addHost( 'h64514' ) |
| 172 | h64515 = self.addHost( 'h64515' ) |
| 173 | h64516 = self.addHost( 'h64516' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 174 | |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 175 | # VLAN hosts behind each AS |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 176 | h64517 = self.addHost( 'h64517', cls=VLANHost, vlan=20 ) |
| 177 | h64518 = self.addHost( 'h64518', cls=VLANHost, vlan=20 ) |
| 178 | h64519 = self.addHost( 'h64519', cls=VLANHost, vlan=10 ) |
| 179 | h64520 = self.addHost( 'h64520', cls=VLANHost, vlan=10 ) |
| 180 | |
| 181 | self.addLink( 'spk1', sw24 ) |
| 182 | self.addLink( 'spk2', sw24 ) |
| 183 | self.addLink( 'spk3', sw24 ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 184 | |
| 185 | # connect all switches |
| 186 | self.addLink( sw1, sw2 ) |
| 187 | self.addLink( sw1, sw6 ) |
| 188 | self.addLink( sw1, sw8 ) |
| 189 | self.addLink( sw2, sw3 ) |
| 190 | self.addLink( sw3, sw4 ) |
| 191 | self.addLink( sw3, sw5 ) |
| 192 | self.addLink( sw4, sw8 ) |
| 193 | self.addLink( sw5, sw7 ) |
| 194 | self.addLink( sw5, sw9 ) |
| 195 | self.addLink( sw6, sw13 ) |
| 196 | self.addLink( sw7, sw8 ) |
| 197 | self.addLink( sw8, sw11 ) |
| 198 | self.addLink( sw9, sw10 ) |
| 199 | self.addLink( sw10, sw12 ) |
| 200 | self.addLink( sw11, sw12 ) |
| 201 | self.addLink( sw11, sw14 ) |
| 202 | self.addLink( sw12, sw17 ) |
| 203 | self.addLink( sw13, sw14 ) |
| 204 | self.addLink( sw13, sw21 ) |
| 205 | self.addLink( sw14, sw15 ) |
| 206 | self.addLink( sw14, sw18 ) |
| 207 | self.addLink( sw14, sw23 ) |
| 208 | self.addLink( sw15, sw16 ) |
| 209 | self.addLink( sw16, sw17 ) |
| 210 | self.addLink( sw17, sw19 ) |
| 211 | self.addLink( sw17, sw20 ) |
| 212 | self.addLink( sw18, sw23 ) |
| 213 | self.addLink( sw19, sw27 ) |
| 214 | self.addLink( sw20, sw28 ) |
| 215 | self.addLink( sw21, sw22 ) |
| 216 | self.addLink( sw21, sw29 ) |
| 217 | self.addLink( sw22, sw23 ) |
| 218 | self.addLink( sw23, sw24 ) |
| 219 | self.addLink( sw23, sw31 ) |
| 220 | self.addLink( sw24, sw25 ) |
| 221 | self.addLink( sw25, sw26 ) |
| 222 | self.addLink( sw26, sw27 ) |
| 223 | self.addLink( sw27, sw28 ) |
| 224 | self.addLink( sw27, sw34 ) |
| 225 | self.addLink( sw29, sw30 ) |
| 226 | self.addLink( sw29, sw35 ) |
| 227 | self.addLink( sw30, sw31 ) |
| 228 | self.addLink( sw31, sw32 ) |
| 229 | self.addLink( sw32, sw33 ) |
| 230 | self.addLink( sw32, sw39 ) |
| 231 | self.addLink( sw33, sw34 ) |
| 232 | self.addLink( sw35, sw36 ) |
| 233 | self.addLink( sw36, sw37 ) |
| 234 | self.addLink( sw37, sw38 ) |
| 235 | self.addLink( sw38, sw39 ) |
| 236 | |
| 237 | # connection between switches and peers |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 238 | self.addLink( p64514, sw32 ) |
| 239 | self.addLink( p64515, sw8 ) |
| 240 | self.addLink( p64516, sw28 ) |
| 241 | |
| 242 | self.addLink( p64517, sw7 ) |
| 243 | self.addLink( p64518, sw9 ) |
| 244 | self.addLink( p64519, sw5 ) |
| 245 | self.addLink( p64520, sw5 ) # should be sw5 |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 246 | |
| 247 | # connection between BGP peer and hosts behind the BGP peer |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 248 | self.addLink( p64514, h64514 ) |
| 249 | self.addLink( p64515, h64515 ) |
| 250 | self.addLink( p64516, h64516 ) |
| 251 | |
| 252 | self.addLink( p64517, h64517 ) |
| 253 | self.addLink( p64518, h64518 ) |
| 254 | self.addLink( p64519, h64519 ) |
| 255 | self.addLink( p64520, h64520 ) |
| 256 | |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 257 | # Internal Connection To Hosts |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 258 | self.addLink( swCtl100, p64514 ) |
| 259 | self.addLink( swCtl100, p64515 ) |
| 260 | self.addLink( swCtl100, p64516 ) |
| 261 | |
| 262 | self.addLink( swCtl100, p64517 ) |
| 263 | self.addLink( swCtl100, p64518 ) |
| 264 | self.addLink( swCtl100, p64519 ) |
| 265 | self.addLink( swCtl100, p64520 ) |
| 266 | |
| 267 | self.addLink( swCtl100, spk1 ) |
| 268 | self.addLink( swCtl100, spk2 ) |
| 269 | self.addLink( swCtl100, spk3 ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 270 | |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 271 | # add h64514 to control plane for ping test |
| 272 | self.addLink( swCtl100, h64514 ) |
| 273 | self.addLink( swCtl100, h64517 ) |
| 274 | self.addLink( swCtl100, h64519 ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 275 | self.addLink( swCtl100, root ) |
| 276 | |
| 277 | |
| 278 | def startsshd( host ): |
| 279 | "Start sshd on host" |
| 280 | info( '*** Starting sshd\n' ) |
| 281 | name, intf, ip = host.name, host.defaultIntf(), host.IP() |
| 282 | banner = '/tmp/%s.banner' % name |
| 283 | host.cmd( 'echo "Welcome to %s at %s" > %s' % ( name, ip, banner ) ) |
| 284 | host.cmd( '/usr/sbin/sshd -o "Banner %s"' % banner, '-o "UseDNS no"' ) |
| 285 | info( '***', host.name, 'is running sshd on', intf, 'at', ip, '\n' ) |
| 286 | |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 287 | |
| 288 | def startsshds( hosts ): |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 289 | for h in hosts: |
| 290 | startsshd( h ) |
| 291 | |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 292 | |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 293 | def stopsshd(): |
| 294 | "Stop *all* sshd processes with a custom banner" |
| 295 | info( '*** Shutting down stale sshd/Banner processes ', |
| 296 | quietRun( "pkill -9 -f Banner" ), '\n' ) |
| 297 | |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 298 | |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 299 | def startquagga( host, num, config_file ): |
| 300 | info( '*** Starting Quagga on %s\n' % host ) |
pingping-lin | 950b50d | 2015-09-14 12:00:08 -0700 | [diff] [blame] | 301 | host.cmd( "cd %s" % QUAGGA_CONFIG_DIR ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 302 | zebra_cmd = \ |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 303 | '%s/zebra -d -f ./zebra.conf -z %s/zserv%s.api -i %s/zebra%s.pid'\ |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 304 | % ( QUAGGA_DIR, QUAGGA_RUN_DIR, num, QUAGGA_RUN_DIR, num ) |
| 305 | quagga_cmd = '%s/bgpd -d -f %s -z %s/zserv%s.api -i %s/bgpd%s.pid' \ |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 306 | % ( QUAGGA_DIR, config_file, QUAGGA_RUN_DIR, num, QUAGGA_RUN_DIR, num ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 307 | |
| 308 | print zebra_cmd |
| 309 | print quagga_cmd |
| 310 | |
| 311 | host.cmd( zebra_cmd ) |
| 312 | host.cmd( quagga_cmd ) |
| 313 | |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 314 | |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 315 | def startquaggahost5( host, num ): |
| 316 | info( '*** Starting Quagga on %s\n' % host ) |
| 317 | zebra_cmd = \ |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 318 | '%s/zebra -d -f ./zebra.conf -z %s/zserv%s.api -i %s/zebra%s.pid' \ |
| 319 | % ( QUAGGA_DIR, QUAGGA_RUN_DIR, num, QUAGGA_RUN_DIR, num ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 320 | quagga_cmd = \ |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 321 | '%s/bgpd -d -f ./as4quaggas/quagga%s.conf -z %s/zserv%s.api -i %s/bgpd%s.pid'\ |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 322 | % ( QUAGGA_DIR, num, QUAGGA_RUN_DIR, num, QUAGGA_RUN_DIR, num ) |
| 323 | |
| 324 | host.cmd( zebra_cmd ) |
| 325 | host.cmd( quagga_cmd ) |
| 326 | |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 327 | |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 328 | def stopquagga(): |
| 329 | quietRun( 'sudo pkill -9 -f bgpd' ) |
| 330 | quietRun( 'sudo pkill -9 -f zebra' ) |
| 331 | |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 332 | |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 333 | def sdn1net(): |
| 334 | topo = SDNTopo() |
| 335 | info( '*** Creating network\n' ) |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 336 | # time.sleep( 30 ) |
| 337 | net = Mininet( topo=topo, controller=RemoteController ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 338 | |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 339 | spk1, spk2, spk3, p64514, p64515, p64516, p64517, p64518, p64519, p64520 = \ |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 340 | net.get( 'spk1', 'spk2', 'spk3', |
| 341 | 'p64514', 'p64515', 'p64516', 'p64517', 'p64518', 'p64519', 'p64520' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 342 | |
| 343 | # Adding addresses to host64513_1 interface connected to sw24 |
| 344 | # for BGP peering |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 345 | spk1.setMAC( '00:00:00:00:00:01', 'spk1-eth0' ) |
| 346 | spk1.cmd( 'ip addr add 10.0.4.101/24 dev spk1-eth0' ) |
| 347 | spk1.cmd( 'ip addr add 10.0.5.101/24 dev spk1-eth0' ) |
| 348 | spk1.cmd( 'ip addr add 10.0.6.101/24 dev spk1-eth0' ) |
| 349 | spk1.defaultIntf().setIP( '10.1.4.101/24' ) |
| 350 | spk1.defaultIntf().setMAC( '00:00:00:00:00:01' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 351 | |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 352 | spk2.setMAC( '00:00:00:00:00:02', 'spk2-eth0.20' ) |
| 353 | spk2.cmd( 'ip addr add 10.0.7.101/24 dev spk2-eth0.20' ) |
| 354 | spk2.cmd( 'ip addr add 10.0.8.101/24 dev spk2-eth0.20' ) |
| 355 | spk2.defaultIntf().setIP( '10.1.7.101/24' ) |
| 356 | spk2.defaultIntf().setMAC( '00:00:00:00:00:02' ) |
| 357 | |
| 358 | spk3.setMAC( '00:00:00:00:00:03', 'spk3-eth0.10' ) |
| 359 | spk3.cmd( 'ip addr add 10.0.9.101/24 dev spk3-eth0.10' ) |
| 360 | spk3.cmd( 'ip addr add 10.0.20.101/24 dev spk3-eth0.10' ) |
| 361 | spk3.defaultIntf().setIP( '10.1.9.101/24' ) |
| 362 | spk3.defaultIntf().setMAC( '00:00:00:00:00:03' ) |
| 363 | |
| 364 | p64517.config( vlan=20, intfName="p64517-eth1", ip="7.0.0.254" ) |
| 365 | p64518.config( vlan=20, intfName="p64518-eth1", ip="8.0.0.254" ) |
| 366 | p64519.config( vlan=10, intfName="p64519-eth1", ip="9.0.0.254" ) |
| 367 | p64520.config( vlan=10, intfName="p64520-eth1", ip="20.0.0.254" ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 368 | |
| 369 | # Net has to be start after adding the above link |
| 370 | net.start() |
| 371 | |
| 372 | # setup configuration on the interface connected to switch |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 373 | p64514.cmd( "ifconfig p64514-eth0 10.0.4.1 up" ) |
| 374 | p64514.setMAC( '00:00:00:00:00:04', 'p64514-eth0' ) |
| 375 | p64515.cmd( "ifconfig p64515-eth0 10.0.5.1 up" ) |
| 376 | p64515.setMAC( '00:00:00:00:00:05', 'p64515-eth0' ) |
| 377 | p64516.cmd( "ifconfig p64516-eth0 10.0.6.1 up" ) |
| 378 | p64516.setMAC( '00:00:00:00:00:06', 'p64516-eth0' ) |
| 379 | |
| 380 | p64517.cmd( "ifconfig p64517-eth0.20 10.0.7.1 up" ) |
| 381 | p64517.setMAC( '00:00:00:00:00:07', 'p64517-eth0.20' ) |
| 382 | p64518.cmd( "ifconfig p64518-eth0.20 10.0.8.1 up" ) |
| 383 | p64518.setMAC( '00:00:00:00:00:08', 'p64518-eth0.20' ) |
| 384 | |
| 385 | p64519.cmd( "ifconfig p64519-eth0.10 10.0.9.1 up" ) |
| 386 | p64519.setMAC( '00:00:00:00:00:09', 'p64519-eth0.10' ) |
| 387 | p64520.cmd( "ifconfig p64520-eth0.10 10.0.20.1 up" ) |
| 388 | p64520.setMAC( '00:00:00:00:00:20', 'p64520-eth0.10' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 389 | |
| 390 | # setup configuration on the interface connected to hosts |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 391 | p64514.setIP( "4.0.0.254", 8, "p64514-eth1" ) |
| 392 | p64514.setMAC( '00:00:00:00:00:44', 'p64514-eth1' ) |
| 393 | p64515.setIP( "5.0.0.254", 8, "p64515-eth1" ) |
| 394 | p64515.setMAC( '00:00:00:00:00:55', 'p64515-eth1' ) |
| 395 | p64516.setIP( "6.0.0.254", 8, "p64516-eth1" ) |
| 396 | p64516.setMAC( '00:00:00:00:00:66', 'p64516-eth1' ) |
| 397 | |
| 398 | p64517.setIP( "7.0.0.254", 8, "p64517-eth1.20" ) |
| 399 | p64517.setMAC( '00:00:00:00:00:77', 'p64517-eth1.20' ) |
| 400 | p64518.setIP( "8.0.0.254", 8, "p64518-eth1.20" ) |
| 401 | p64518.setMAC( '00:00:00:00:00:88', 'p64518-eth1.20' ) |
| 402 | |
| 403 | p64519.setIP( "9.0.0.254", 8, "p64519-eth1.10" ) |
| 404 | p64519.setMAC( '00:00:00:00:00:99', 'p64519-eth1.10' ) |
| 405 | p64520.setIP( "20.0.0.254", 8, "p64520-eth1.10" ) |
| 406 | p64520.setMAC( '00:00:00:00:00:20', 'p64520-eth1.10' ) |
| 407 | |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 408 | # enable forwarding on BGP peer hosts |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 409 | p64514.cmd( 'sysctl net.ipv4.conf.all.forwarding=1' ) |
| 410 | p64515.cmd( 'sysctl net.ipv4.conf.all.forwarding=1' ) |
| 411 | p64516.cmd( 'sysctl net.ipv4.conf.all.forwarding=1' ) |
| 412 | |
| 413 | p64517.cmd( 'sysctl net.ipv4.conf.all.forwarding=1' ) |
| 414 | p64518.cmd( 'sysctl net.ipv4.conf.all.forwarding=1' ) |
| 415 | p64519.cmd( 'sysctl net.ipv4.conf.all.forwarding=1' ) |
| 416 | p64520.cmd( 'sysctl net.ipv4.conf.all.forwarding=1' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 417 | |
| 418 | # config interface for control plane connectivity |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 419 | p64514.setIP( "192.168.0.4", 24, "p64514-eth2" ) |
| 420 | p64515.setIP( "192.168.0.5", 24, "p64515-eth2" ) |
| 421 | p64516.setIP( "192.168.0.6", 24, "p64516-eth2" ) |
| 422 | |
| 423 | p64517.setIP( "192.168.0.7", 24, "p64517-eth2" ) |
| 424 | p64518.setIP( "192.168.0.8", 24, "p64518-eth2" ) |
| 425 | p64519.setIP( "192.168.0.9", 24, "p64519-eth2" ) |
| 426 | p64520.setIP( "192.168.0.20", 24, "p64520-eth2" ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 427 | |
| 428 | # Setup hosts in each non-SDN AS |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 429 | h64514, h64515, h64516, h64517, h64518, h64519, h64520 = \ |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 430 | net.get( 'h64514', 'h64515', 'h64516', 'h64517', 'h64518', 'h64519', 'h64520' ) |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 431 | h64514.cmd( 'ifconfig h64514-eth0 4.0.0.1 up' ) |
| 432 | h64514.cmd( 'ip route add default via 4.0.0.254' ) |
| 433 | h64514.setIP( '192.168.0.44', 24, 'h64514-eth1' ) # for control plane |
| 434 | h64515.cmd( 'ifconfig h64515-eth0 5.0.0.1 up' ) |
| 435 | h64515.cmd( 'ip route add default via 5.0.0.254' ) |
| 436 | h64516.cmd( 'ifconfig h64516-eth0 6.0.0.1 up' ) |
| 437 | h64516.cmd( 'ip route add default via 6.0.0.254' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 438 | |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 439 | h64517.cmd( 'ifconfig h64517-eth0.20 7.0.0.1 up' ) |
| 440 | h64517.cmd( 'ip route add default via 7.0.0.254' ) |
| 441 | h64517.setIP( '192.168.0.77', 24, 'h64517-eth1' ) # for control plane |
| 442 | h64518.cmd( 'ifconfig h64518-eth0.20 8.0.0.1 up' ) |
| 443 | h64518.cmd( 'ip route add default via 8.0.0.254' ) |
| 444 | |
| 445 | h64519.cmd( 'ifconfig h64519-eth0.10 9.0.0.1 up' ) |
| 446 | h64519.cmd( 'ip route add default via 9.0.0.254' ) |
| 447 | h64519.setIP( '192.168.0.99', 24, 'h64519-eth1' ) # for control plane |
| 448 | h64520.cmd( 'ifconfig h64520-eth0.10 20.0.0.1 up' ) |
| 449 | h64520.cmd( 'ip route add default via 20.0.0.254' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 450 | |
| 451 | # set up swCtl100 as a learning |
| 452 | swCtl100 = net.get( 'swCtl100' ) |
| 453 | swCtl100.cmd( 'ovs-vsctl set-controller swCtl100 none' ) |
| 454 | swCtl100.cmd( 'ovs-vsctl set-fail-mode swCtl100 standalone' ) |
| 455 | |
| 456 | # connect all switches to controller |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 457 | """ |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 458 | for i in range ( 1, numSw + 1 ): |
| 459 | swX = net.get( 'sw%s' % ( i ) ) |
Charles Chan | 029be65 | 2015-08-24 01:46:10 +0800 | [diff] [blame] | 460 | swX.cmd( 'ovs-vsctl set-controller sw%s tcp:%s:6653' % ( i, onos1IP ) ) |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 461 | """ |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 462 | # Start Quagga as the external BGP routers |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 463 | """ |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 464 | for i in range ( 64514, 64516 + 1 ): |
| 465 | startquagga( 'peer%s' % ( i ), i, 'quagga%s.conf' % ( i ) ) |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 466 | """ |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 467 | startquagga( p64514, 64514, 'quagga64514.conf' ) |
| 468 | startquagga( p64515, 64515, 'quagga64515.conf' ) |
| 469 | startquagga( p64516, 64516, 'quagga64516.conf' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 470 | |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 471 | startquagga( p64517, 64517, 'quagga64517.conf' ) |
| 472 | startquagga( p64518, 64518, 'quagga64518.conf' ) |
| 473 | startquagga( p64519, 64519, 'quagga64519.conf' ) |
| 474 | startquagga( p64520, 64520, 'quagga64520.conf' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 475 | |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 476 | # start Quagga as the BGP speaker |
| 477 | startquagga( spk1, 64513, 'quagga-sdn.conf' ) |
| 478 | startquagga( spk2, 64512, 'quagga-sdn2.conf' ) |
| 479 | startquagga( spk3, 64511, 'quagga-sdn3.conf' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 480 | |
| 481 | root = net.get( 'root' ) |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 482 | |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 483 | root.intf( 'root-eth0' ).setIP( '1.1.1.2/24' ) |
| 484 | root.cmd( 'ip addr add 192.168.0.100/24 dev root-eth0' ) |
| 485 | |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 486 | spk1.intf( 'spk1-eth1' ).setIP( '1.1.1.1/24' ) |
| 487 | spk2.intf( 'spk2-eth1' ).setIP( '1.1.1.3/24' ) |
| 488 | spk3.intf( 'spk3-eth1' ).setIP( '1.1.1.5/24' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 489 | |
| 490 | stopsshd() |
| 491 | |
alison | e4121a9 | 2016-11-22 16:31:36 -0800 | [diff] [blame] | 492 | hosts = [ p64514, p64515, p64516, p64517, p64518, p64519, p64520, |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 493 | h64514, h64517, h64519 ] |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 494 | startsshds( hosts ) |
| 495 | # |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 496 | """ |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 497 | forwarding1 = '%s:2000:%s:2000' % ( '1.1.1.2', onos1IP ) |
| 498 | root.cmd( 'ssh -nNT -o "PasswordAuthentication no" \ |
| 499 | -o "StrictHostKeyChecking no" -l sdn -L %s %s & ' % ( forwarding1, onos1IP ) ) |
| 500 | |
Jeremy Ronquillo | 23fb216 | 2017-09-15 14:59:57 -0700 | [diff] [blame] | 501 | """ |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 502 | # time.sleep( 3000000000 ) |
| 503 | CLI( net ) |
| 504 | |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 505 | stopsshd() |
| 506 | stopquagga() |
| 507 | net.stop() |
| 508 | |
| 509 | if __name__ == '__main__': |
pingping-lin | 950b50d | 2015-09-14 12:00:08 -0700 | [diff] [blame] | 510 | setLogLevel( 'debug' ) |
pingping-lin | 117a43b | 2015-09-08 17:40:53 -0700 | [diff] [blame] | 511 | sdn1net() |