Skip to content
Snippets Groups Projects
Commit 7df36e47 authored by Bob Lantz's avatar Bob Lantz
Browse files

Changed linearbandwidth.py to be much (!) smarter - it now *reuses* the network! Amazing.

parent f939eb56
No related branches found
No related tags found
No related merge requests found
......@@ -4,32 +4,70 @@
Test bandwidth (using iperf) on linear networks of varying size,
using both kernel and user datapaths.
Each network looks like:
h0 <-> s0 <-> s1 .. sN <-> h1
Each network has N switches and N+1 hosts, connected as follows:
h0 <-> s0 <-> s1 .. sN-1
| | |
h1 h2 hN
Note: by default, the reference controller only supports 16
switches, so this test WILL NOT WORK unless you have recompiled
your controller to support a 100 switches (or more.)
your controller to support 100 switches (or more.)
"""
from mininet import init, LinearNet, iperfTest
from mininet import init, Network, defaultNames, Host, Switch
from mininet import createLink, flush, iperf, pingTestVerbose, Cli
def linearBandwidthTest():
class LinearNet( Network ):
def __init__( self, switchCount, **kwargs ):
self.switchCount = switchCount
Network.__init__( self, **kwargs )
def makeNet( self, controller ):
snames, hnames, dpnames = defaultNames()
previous = None
hosts = []
switches = []
def newHost( switch ):
host = Host( hnames.next() )
createLink( host, switch )
print host.name, ; flush()
return [ host ]
print "*** Creating linear network of size", self.switchCount
for s in range( 0, self.switchCount ):
dp = dpnames.next() if self.kernel else None
switch = Switch( snames.next(), dp )
switches += [ switch ]
print switch.name, ; flush()
if not self.kernel: createLink( controller, switch )
if s == 0: hosts += newHost( switch )
hosts += newHost( switch)
if previous is not None: createLink( previous, switch)
previous = switch
return switches, hosts
def linearBandwidthTest( lengths ):
"Check bandwidth at various lengths along a switch chain."
datapaths = [ 'kernel', 'user' ]
switchCounts = [ 1, 20, 40, 60, 80, 100 ]
results = {}
switchCount = max( lengths )
for datapath in datapaths:
k = datapath == 'kernel'
results[ datapath ] = []
for switchCount in switchCounts:
print "*** Creating linear network of size", switchCount
network = LinearNet( switchCount, kernel=k)
bandwidth = network.run( iperfTest )
results[ datapath ] += [ ( switchCount, bandwidth ) ]
network = LinearNet( switchCount, kernel=k)
network.start()
for n in lengths:
def test( controllers, switches, hosts ):
print "testing h0 <-> h" + `n`, ; flush()
result = iperf( [ hosts[ 0 ], hosts[ n ] ] )
print result ; flush()
return result
bandwidth = network.runTest( test )
results[ datapath ] += [ ( n, bandwidth ) ]
network.stop()
for datapath in datapaths:
print
print "*** Linear network results for", datapath, "datapath:"
......@@ -45,7 +83,6 @@ def linearBandwidthTest():
if __name__ == '__main__':
init()
print "*** Running linearBandwidthTest"
linearBandwidthTest()
exit( 1 )
linearBandwidthTest( [ 1, 10, 20, 40, 80, 100 ] )
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment