diff --git a/daemon/core/netns/vnode.py b/daemon/core/netns/vnode.py index 3f50d028..a50ebb07 100644 --- a/daemon/core/netns/vnode.py +++ b/daemon/core/netns/vnode.py @@ -117,10 +117,9 @@ class SimpleLxcNode(PyCoreNode): if not self.up: return - # unmount all targets - while self._mounts: - source, target = self._mounts.pop(-1) - self.umount(target) + # unmount all targets (NOTE: non-persistent mount namespaces are + # removed by the kernel when last referencing process is killed) + self._mounts = [] # shutdown all interfaces for netif in self.netifs(): @@ -250,19 +249,6 @@ class SimpleLxcNode(PyCoreNode): except IOError: logger.exception("mounting failed for %s at %s", source, target) - def umount(self, target): - """ - Unmount a target directory. - - :param str target: target directory to unmount - :return: nothing - """ - logger.info("unmounting: %s", target) - try: - self.cmd([constants.UMOUNT_BIN, "-n", "-l", target]) - except IOError: - logger.exception("unmounting failed for %s" % target) - def newifindex(self): """ Retrieve a new interface index.