Commit c90becea authored by Yonghong Song's avatar Yonghong Song

better clean up of created namespace/interfaces if ctrl-c is pressed

  o There are still some cases when ctrl-c is pressed, the program does not exit
    gracefully, with a however lower probability. In my random manual experiments,
    one in ten cases it still hangs and needs further ctrl-z.
Signed-off-by: default avatarYonghong Song <yhs@plumgrid.com>
parent 2ac4b662
...@@ -24,7 +24,15 @@ class Simulation(object): ...@@ -24,7 +24,15 @@ class Simulation(object):
if name in self.ipdbs: if name in self.ipdbs:
ns_ipdb = self.ipdbs[name] ns_ipdb = self.ipdbs[name]
else: else:
ns_ipdb = IPDB(nl=NetNS(name)) try:
nl=NetNS(name)
self.namespaces.append(nl)
except KeyboardInterrupt:
# remove the namespace if it has been created
pyroute2.netns.remove(name)
raise
ns_ipdb = IPDB(nl)
self.ipdbs[nl.netns] = ns_ipdb
if disable_ipv6: if disable_ipv6:
cmd = ["sysctl", "-q", "-w", cmd = ["sysctl", "-q", "-w",
"net.ipv6.conf.default.disable_ipv6=1"] "net.ipv6.conf.default.disable_ipv6=1"]
...@@ -33,17 +41,26 @@ class Simulation(object): ...@@ -33,17 +41,26 @@ class Simulation(object):
ns_ipdb.interfaces.lo.up().commit() ns_ipdb.interfaces.lo.up().commit()
if in_ifc: if in_ifc:
in_ifname = in_ifc.ifname in_ifname = in_ifc.ifname
with in_ifc as v:
# move half of veth into namespace
v.net_ns_fd = ns_ipdb.nl.netns
else: else:
out_ifc = self.ipdb.create(ifname="%sa" % ifc_base_name, kind="veth", try:
peer="%sb" % ifc_base_name).commit() out_ifc = self.ipdb.create(ifname="%sa" % ifc_base_name, kind="veth",
in_ifc = self.ipdb.interfaces[out_ifc.peer] peer="%sb" % ifc_base_name).commit()
in_ifname = in_ifc.ifname in_ifc = self.ipdb.interfaces[out_ifc.peer]
with in_ifc as v: in_ifname = in_ifc.ifname
# move half of veth into namespace with in_ifc as v:
v.net_ns_fd = ns_ipdb.nl.netns v.net_ns_fd = ns_ipdb.nl.netns
in_ifc = ns_ipdb.interfaces[in_ifname] except KeyboardInterrupt:
# explicitly remove the interface
out_ifname = "%sa" % ifc_base_name
if out_ifname in self.ipdb.interfaces: self.ipdb.interfaces[out_ifname].remove().commit()
raise
if out_ifc: out_ifc.up().commit() if out_ifc: out_ifc.up().commit()
ns_ipdb.interfaces.lo.up().commit() ns_ipdb.interfaces.lo.up().commit()
in_ifc = ns_ipdb.interfaces[in_ifname]
with in_ifc as v: with in_ifc as v:
v.ifname = ns_ifc v.ifname = ns_ifc
if ipaddr: v.add_ip("%s" % ipaddr) if ipaddr: v.add_ip("%s" % ipaddr)
...@@ -68,8 +85,6 @@ class Simulation(object): ...@@ -68,8 +85,6 @@ class Simulation(object):
(ns_ipdb, out_ifc, in_ifc) = self._ns_add_ifc(name, "eth0", name, in_ifc, out_ifc, (ns_ipdb, out_ifc, in_ifc) = self._ns_add_ifc(name, "eth0", name, in_ifc, out_ifc,
ipaddr, macaddr, fn, cmd, action, ipaddr, macaddr, fn, cmd, action,
disable_ipv6) disable_ipv6)
self.ipdbs[ns_ipdb.nl.netns] = ns_ipdb
self.namespaces.append(ns_ipdb.nl)
return (ns_ipdb, out_ifc, in_ifc) return (ns_ipdb, out_ifc, in_ifc)
def release(self): def release(self):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment