Skip to content
Snippets Groups Projects
Commit ffeb16eb authored by Brian O'Connor's avatar Brian O'Connor
Browse files

fixing --nat option in mn

parent a802d8b1
No related branches found
No related tags found
No related merge requests found
......@@ -226,8 +226,6 @@ class MininetRunner( object ):
start = time.time()
topo = buildTopo( TOPOS, self.options.topo )
if self.options.nat:
topo.addNAT()
switch = customConstructor( SWITCHES, self.options.switch )
host = customConstructor( HOSTS, self.options.host )
controller = customConstructor( CONTROLLERS, self.options.controller )
......@@ -255,6 +253,10 @@ class MininetRunner( object ):
autoStaticArp=arp, autoPinCpus=pin,
listenPort=listenPort )
if self.options.nat:
nat = mn.addNAT()
mn.configHosts()
if self.options.pre:
CLI( mn, script=self.options.pre )
......
......@@ -56,7 +56,7 @@ def __init__(self, n=2, h=1, **opts):
defaultRoute='via %s' % localIP)
self.addLink(host, switch)
def perfTest():
def run():
"Create network and run simple performance test"
topo = InternetTopo()
net = Mininet(topo=topo)
......@@ -66,4 +66,4 @@ def perfTest():
if __name__ == '__main__':
setLogLevel('info')
perfTest()
\ No newline at end of file
run()
\ No newline at end of file
......@@ -227,14 +227,18 @@ def addController( self, name='c0', controller=None, **params ):
self.nameToNode[ name ] = controller_new
return controller_new
# TODO: incomplete
def addNAT( self, name='nat0', connect=True, **params ):
nat = self.addHost( name, cls=NAT, **params )
def addNAT( self, name='nat0', connect=True, inNamespace=False, **params ):
nat = self.addHost( name, cls=NAT, inNamespace=inNamespace,
subnet=self.ipBase, **params )
# find first switch and create link
print "******* &&&&&& net/addNAT"
if connect:
#connect the nat to the first switch
# connect the nat to the first switch
self.addLink( nat, self.switches[ 0 ] )
# set the default route on hosts
natIP = nat.params[ 'ip' ].split('/')[ 0 ]
for host in self.hosts:
if host.inNamespace:
host.setDefaultRoute( 'via %s' % natIP )
return nat
# BL: We now have four ways to look up nodes
......
......@@ -1253,7 +1253,7 @@ def __init__( self, name, inetIntf='eth0', subnet='10.0/8', localIntf=None, **pa
inetIntf: interface for internet access
subnet: Mininet subnet (default 10.0/8)="""
self.inetIntf = inetIntf
self.subnet = subnet #TODO: get subnet from Mininet directly
self.subnet = subnet
self.localIntf = localIntf
def config( self, **params ):
......@@ -1263,13 +1263,6 @@ def config( self, **params ):
if not self.localIntf:
self.localIntf = self.defaultIntf()
#-------------------------
print "inetIntf:", self.inetIntf
print "subnet:", self.subnet
# Identify the interface connecting to the mininet network
print "LocalIntf:", self.localIntf
#-------------------------
self.cmd( 'sysctl net.ipv4.ip_forward=0' )
# Flush any currently active rules
......
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