mirror of
https://github.com/GNS3/gns3-server.git
synced 2025-01-18 07:23:47 +02:00
Properly release UDP ports when closing a project or deleting a link.
This commit is contained in:
parent
3d3300e83a
commit
42c07cee1a
@ -32,9 +32,9 @@ from ..config import Config
|
|||||||
from ..utils.asyncio import wait_run_in_executor
|
from ..utils.asyncio import wait_run_in_executor
|
||||||
from .project_manager import ProjectManager
|
from .project_manager import ProjectManager
|
||||||
|
|
||||||
from .nios.nio_udp import NIO_UDP
|
from .nios.nio_udp import NIOUDP
|
||||||
from .nios.nio_tap import NIO_TAP
|
from .nios.nio_tap import NIOTAP
|
||||||
from .nios.nio_generic_ethernet import NIO_GenericEthernet
|
from .nios.nio_generic_ethernet import NIOGenericEthernet
|
||||||
|
|
||||||
|
|
||||||
class BaseManager:
|
class BaseManager:
|
||||||
@ -283,13 +283,13 @@ class BaseManager:
|
|||||||
sock.connect((rhost, rport))
|
sock.connect((rhost, rport))
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
raise aiohttp.web.HTTPInternalServerError(text="Could not create an UDP connection to {}:{}: {}".format(rhost, rport, e))
|
raise aiohttp.web.HTTPInternalServerError(text="Could not create an UDP connection to {}:{}: {}".format(rhost, rport, e))
|
||||||
nio = NIO_UDP(lport, rhost, rport)
|
nio = NIOUDP(lport, rhost, rport)
|
||||||
elif nio_settings["type"] == "nio_tap":
|
elif nio_settings["type"] == "nio_tap":
|
||||||
tap_device = nio_settings["tap_device"]
|
tap_device = nio_settings["tap_device"]
|
||||||
if not self._has_privileged_access(executable):
|
if not self._has_privileged_access(executable):
|
||||||
raise aiohttp.web.HTTPForbidden(text="{} has no privileged access to {}.".format(executable, tap_device))
|
raise aiohttp.web.HTTPForbidden(text="{} has no privileged access to {}.".format(executable, tap_device))
|
||||||
nio = NIO_TAP(tap_device)
|
nio = NIOTAP(tap_device)
|
||||||
elif nio_settings["type"] == "nio_generic_ethernet":
|
elif nio_settings["type"] == "nio_generic_ethernet":
|
||||||
nio = NIO_GenericEthernet(nio_settings["ethernet_device"])
|
nio = NIOGenericEthernet(nio_settings["ethernet_device"])
|
||||||
assert nio is not None
|
assert nio is not None
|
||||||
return nio
|
return nio
|
||||||
|
@ -46,7 +46,6 @@ from .dynamips_device import DynamipsDevice
|
|||||||
|
|
||||||
# NIOs
|
# NIOs
|
||||||
from .nios.nio_udp import NIOUDP
|
from .nios.nio_udp import NIOUDP
|
||||||
from .nios.nio_udp_auto import NIOUDPAuto
|
|
||||||
from .nios.nio_unix import NIOUNIX
|
from .nios.nio_unix import NIOUNIX
|
||||||
from .nios.nio_vde import NIOVDE
|
from .nios.nio_vde import NIOVDE
|
||||||
from .nios.nio_tap import NIOTAP
|
from .nios.nio_tap import NIOTAP
|
||||||
@ -355,13 +354,7 @@ class Dynamips(BaseManager):
|
|||||||
sock.connect((rhost, rport))
|
sock.connect((rhost, rport))
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
raise DynamipsError("Could not create an UDP connection to {}:{}: {}".format(rhost, rport, e))
|
raise DynamipsError("Could not create an UDP connection to {}:{}: {}".format(rhost, rport, e))
|
||||||
# check if we have an allocated NIO UDP auto
|
|
||||||
#nio = node.hypervisor.get_nio_udp_auto(lport)
|
|
||||||
# if not nio:
|
|
||||||
# otherwise create an NIO UDP
|
|
||||||
nio = NIOUDP(node.hypervisor, lport, rhost, rport)
|
nio = NIOUDP(node.hypervisor, lport, rhost, rport)
|
||||||
# else:
|
|
||||||
# nio.connect(rhost, rport)
|
|
||||||
elif nio_settings["type"] == "nio_generic_ethernet":
|
elif nio_settings["type"] == "nio_generic_ethernet":
|
||||||
ethernet_device = nio_settings["ethernet_device"]
|
ethernet_device = nio_settings["ethernet_device"]
|
||||||
if sys.platform.startswith("win"):
|
if sys.platform.startswith("win"):
|
||||||
|
@ -25,7 +25,6 @@ import logging
|
|||||||
import asyncio
|
import asyncio
|
||||||
|
|
||||||
from .dynamips_error import DynamipsError
|
from .dynamips_error import DynamipsError
|
||||||
from .nios.nio_udp_auto import NIOUDPAuto
|
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -53,7 +52,6 @@ class DynamipsHypervisor:
|
|||||||
|
|
||||||
self._devices = []
|
self._devices = []
|
||||||
self._working_dir = working_dir
|
self._working_dir = working_dir
|
||||||
self._nio_udp_auto_instances = {}
|
|
||||||
self._version = "N/A"
|
self._version = "N/A"
|
||||||
self._timeout = timeout
|
self._timeout = timeout
|
||||||
self._uuid = None
|
self._uuid = None
|
||||||
@ -130,7 +128,6 @@ class DynamipsHypervisor:
|
|||||||
except OSError as e:
|
except OSError as e:
|
||||||
log.debug("Stopping hypervisor {}:{} {}".format(self._host, self._port, e))
|
log.debug("Stopping hypervisor {}:{} {}".format(self._host, self._port, e))
|
||||||
self._reader = self._writer = None
|
self._reader = self._writer = None
|
||||||
self._nio_udp_auto_instances.clear()
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
@asyncio.coroutine
|
||||||
def reset(self):
|
def reset(self):
|
||||||
@ -139,7 +136,6 @@ class DynamipsHypervisor:
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
yield from self.send("hypervisor reset")
|
yield from self.send("hypervisor reset")
|
||||||
self._nio_udp_auto_instances.clear()
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
@asyncio.coroutine
|
||||||
def set_working_dir(self, working_dir):
|
def set_working_dir(self, working_dir):
|
||||||
@ -224,31 +220,6 @@ class DynamipsHypervisor:
|
|||||||
|
|
||||||
self._host = host
|
self._host = host
|
||||||
|
|
||||||
def get_nio_udp_auto(self, port):
|
|
||||||
"""
|
|
||||||
Returns an allocated NIO UDP auto instance.
|
|
||||||
|
|
||||||
:returns: NIO UDP auto instance
|
|
||||||
"""
|
|
||||||
|
|
||||||
if port in self._nio_udp_auto_instances:
|
|
||||||
return self._nio_udp_auto_instances.pop(port)
|
|
||||||
else:
|
|
||||||
return None
|
|
||||||
|
|
||||||
def allocate_udp_port(self):
|
|
||||||
"""
|
|
||||||
Allocates a new UDP port for creating an UDP NIO Auto.
|
|
||||||
|
|
||||||
:returns: port number (integer)
|
|
||||||
"""
|
|
||||||
|
|
||||||
# use Dynamips's NIO UDP auto back-end.
|
|
||||||
nio = NIOUDPAuto(self, self._host, self._udp_start_port_range, self._udp_end_port_range)
|
|
||||||
self._nio_udp_auto_instances[nio.lport] = nio
|
|
||||||
allocated_port = nio.lport
|
|
||||||
return allocated_port
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
@asyncio.coroutine
|
||||||
def send(self, command):
|
def send(self, command):
|
||||||
"""
|
"""
|
||||||
|
@ -1,140 +0,0 @@
|
|||||||
# -*- coding: utf-8 -*-
|
|
||||||
#
|
|
||||||
# Copyright (C) 2013 GNS3 Technologies Inc.
|
|
||||||
#
|
|
||||||
# This program is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
"""
|
|
||||||
Interface for automatic UDP NIOs.
|
|
||||||
"""
|
|
||||||
|
|
||||||
import asyncio
|
|
||||||
from .nio import NIO
|
|
||||||
|
|
||||||
import logging
|
|
||||||
log = logging.getLogger(__name__)
|
|
||||||
|
|
||||||
|
|
||||||
class NIOUDPAuto(NIO):
|
|
||||||
|
|
||||||
"""
|
|
||||||
Dynamips auto UDP NIO.
|
|
||||||
|
|
||||||
:param hypervisor: Dynamips hypervisor instance
|
|
||||||
:param laddr: local address
|
|
||||||
:param lport_start: start local port range
|
|
||||||
:param lport_end: end local port range
|
|
||||||
"""
|
|
||||||
|
|
||||||
_instance_count = 0
|
|
||||||
|
|
||||||
def __init__(self, hypervisor, laddr, lport_start, lport_end):
|
|
||||||
|
|
||||||
# create an unique ID and name
|
|
||||||
nio_id = NIOUDPAuto._instance_count
|
|
||||||
NIOUDPAuto._instance_count += 1
|
|
||||||
name = 'nio_udp_auto' + str(nio_id)
|
|
||||||
self._laddr = laddr
|
|
||||||
self._lport = None
|
|
||||||
self._raddr = None
|
|
||||||
self._rport = None
|
|
||||||
NIO.__init__(self, name, hypervisor)
|
|
||||||
|
|
||||||
@classmethod
|
|
||||||
def reset(cls):
|
|
||||||
"""
|
|
||||||
Reset the instance count.
|
|
||||||
"""
|
|
||||||
|
|
||||||
cls._instance_count = 0
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
|
||||||
def create(self):
|
|
||||||
|
|
||||||
port = yield from self._hypervisor.send("nio create_udp_auto {name} {laddr} {lport_start} {lport_end}".format(name=self._name,
|
|
||||||
laddr=self._laddr,
|
|
||||||
lport_start=self._lport_start,
|
|
||||||
lport_end=self._lport_end))
|
|
||||||
self._lport = int(port[0])
|
|
||||||
|
|
||||||
log.info("NIO UDP AUTO {name} created with laddr={laddr}, lport_start={start}, lport_end={end}".format(name=self._name,
|
|
||||||
laddr=self._laddr,
|
|
||||||
start=self._lport_start,
|
|
||||||
end=self._lport_end))
|
|
||||||
|
|
||||||
@property
|
|
||||||
def laddr(self):
|
|
||||||
"""
|
|
||||||
Returns the local address
|
|
||||||
|
|
||||||
:returns: local address
|
|
||||||
"""
|
|
||||||
|
|
||||||
return self._laddr
|
|
||||||
|
|
||||||
@property
|
|
||||||
def lport(self):
|
|
||||||
"""
|
|
||||||
Returns the local port
|
|
||||||
|
|
||||||
:returns: local port number
|
|
||||||
"""
|
|
||||||
|
|
||||||
return self._lport
|
|
||||||
|
|
||||||
@property
|
|
||||||
def raddr(self):
|
|
||||||
"""
|
|
||||||
Returns the remote address
|
|
||||||
|
|
||||||
:returns: remote address
|
|
||||||
"""
|
|
||||||
|
|
||||||
return self._raddr
|
|
||||||
|
|
||||||
@property
|
|
||||||
def rport(self):
|
|
||||||
"""
|
|
||||||
Returns the remote port
|
|
||||||
|
|
||||||
:returns: remote port number
|
|
||||||
"""
|
|
||||||
|
|
||||||
return self._rport
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
|
||||||
def connect(self, raddr, rport):
|
|
||||||
"""
|
|
||||||
Connects this NIO to a remote socket
|
|
||||||
|
|
||||||
:param raddr: remote address
|
|
||||||
:param rport: remote port number
|
|
||||||
"""
|
|
||||||
|
|
||||||
yield from self._hypervisor.send("nio connect_udp_auto {name} {raddr} {rport}".format(name=self._name,
|
|
||||||
raddr=raddr,
|
|
||||||
rport=rport))
|
|
||||||
self._raddr = raddr
|
|
||||||
self._rport = rport
|
|
||||||
|
|
||||||
log.info("NIO UDP AUTO {name} connected to {raddr}:{rport}".format(name=self._name,
|
|
||||||
raddr=raddr,
|
|
||||||
rport=rport))
|
|
||||||
|
|
||||||
def __json__(self):
|
|
||||||
|
|
||||||
return {"type": "nio_udp_auto",
|
|
||||||
"lport": self._lport,
|
|
||||||
"rport": self._rport,
|
|
||||||
"raddr": self._raddr}
|
|
@ -24,6 +24,7 @@ import asyncio
|
|||||||
import re
|
import re
|
||||||
|
|
||||||
from .device import Device
|
from .device import Device
|
||||||
|
from ..nios.nio_udp import NIOUDP
|
||||||
from ..dynamips_error import DynamipsError
|
from ..dynamips_error import DynamipsError
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
@ -106,6 +107,10 @@ class ATMSwitch(Device):
|
|||||||
Deletes this ATM switch.
|
Deletes this ATM switch.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
for nio in self._nios.values():
|
||||||
|
if nio and isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
yield from self._hypervisor.send('atmsw delete "{}"'.format(self._name))
|
yield from self._hypervisor.send('atmsw delete "{}"'.format(self._name))
|
||||||
log.info('ATM switch "{name}" [{id}] has been deleted'.format(name=self._name, id=self._id))
|
log.info('ATM switch "{name}" [{id}] has been deleted'.format(name=self._name, id=self._id))
|
||||||
@ -155,6 +160,8 @@ class ATMSwitch(Device):
|
|||||||
raise DynamipsError("Port {} is not allocated".format(port_number))
|
raise DynamipsError("Port {} is not allocated".format(port_number))
|
||||||
|
|
||||||
nio = self._nios[port_number]
|
nio = self._nios[port_number]
|
||||||
|
if isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
log.info('ATM switch "{name}" [{id}]: NIO {nio} removed from port {port}'.format(name=self._name,
|
log.info('ATM switch "{name}" [{id}]: NIO {nio} removed from port {port}'.format(name=self._name,
|
||||||
id=self._id,
|
id=self._id,
|
||||||
nio=nio,
|
nio=nio,
|
||||||
|
@ -22,6 +22,7 @@ Hub object that uses the Bridge interface to create a hub with ports.
|
|||||||
import asyncio
|
import asyncio
|
||||||
|
|
||||||
from .bridge import Bridge
|
from .bridge import Bridge
|
||||||
|
from ..nios.nio_udp import NIOUDP
|
||||||
from ..dynamips_error import DynamipsError
|
from ..dynamips_error import DynamipsError
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
@ -73,6 +74,10 @@ class EthernetHub(Bridge):
|
|||||||
Deletes this hub.
|
Deletes this hub.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
for nio in self._nios.values():
|
||||||
|
if nio and isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
yield from Bridge.delete(self)
|
yield from Bridge.delete(self)
|
||||||
log.info('Ethernet hub "{name}" [{id}] has been deleted'.format(name=self._name, id=self._id))
|
log.info('Ethernet hub "{name}" [{id}] has been deleted'.format(name=self._name, id=self._id))
|
||||||
@ -115,6 +120,8 @@ class EthernetHub(Bridge):
|
|||||||
raise DynamipsError("Port {} is not allocated".format(port_number))
|
raise DynamipsError("Port {} is not allocated".format(port_number))
|
||||||
|
|
||||||
nio = self._mappings[port_number]
|
nio = self._mappings[port_number]
|
||||||
|
if isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
yield from Bridge.remove_nio(self, nio)
|
yield from Bridge.remove_nio(self, nio)
|
||||||
|
|
||||||
log.info('Ethernet switch "{name}" [{id}]: NIO {nio} removed from port {port}'.format(name=self._name,
|
log.info('Ethernet switch "{name}" [{id}]: NIO {nio} removed from port {port}'.format(name=self._name,
|
||||||
|
@ -23,6 +23,7 @@ http://github.com/GNS3/dynamips/blob/master/README.hypervisor#L558
|
|||||||
import asyncio
|
import asyncio
|
||||||
|
|
||||||
from .device import Device
|
from .device import Device
|
||||||
|
from ..nios.nio_udp import NIOUDP
|
||||||
from ..dynamips_error import DynamipsError
|
from ..dynamips_error import DynamipsError
|
||||||
|
|
||||||
|
|
||||||
@ -114,6 +115,10 @@ class EthernetSwitch(Device):
|
|||||||
Deletes this Ethernet switch.
|
Deletes this Ethernet switch.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
for nio in self._nios.values():
|
||||||
|
if nio and isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
yield from self._hypervisor.send('ethsw delete "{}"'.format(self._name))
|
yield from self._hypervisor.send('ethsw delete "{}"'.format(self._name))
|
||||||
log.info('Ethernet switch "{name}" [{id}] has been deleted'.format(name=self._name, id=self._id))
|
log.info('Ethernet switch "{name}" [{id}] has been deleted'.format(name=self._name, id=self._id))
|
||||||
@ -157,6 +162,8 @@ class EthernetSwitch(Device):
|
|||||||
raise DynamipsError("Port {} is not allocated".format(port_number))
|
raise DynamipsError("Port {} is not allocated".format(port_number))
|
||||||
|
|
||||||
nio = self._nios[port_number]
|
nio = self._nios[port_number]
|
||||||
|
if isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
yield from self._hypervisor.send('ethsw remove_nio "{name}" {nio}'.format(name=self._name, nio=nio))
|
yield from self._hypervisor.send('ethsw remove_nio "{name}" {nio}'.format(name=self._name, nio=nio))
|
||||||
|
|
||||||
log.info('Ethernet switch "{name}" [{id}]: NIO {nio} removed from port {port}'.format(name=self._name,
|
log.info('Ethernet switch "{name}" [{id}]: NIO {nio} removed from port {port}'.format(name=self._name,
|
||||||
|
@ -23,6 +23,7 @@ http://github.com/GNS3/dynamips/blob/master/README.hypervisor#L642
|
|||||||
import asyncio
|
import asyncio
|
||||||
|
|
||||||
from .device import Device
|
from .device import Device
|
||||||
|
from ..nios.nio_udp import NIOUDP
|
||||||
from ..dynamips_error import DynamipsError
|
from ..dynamips_error import DynamipsError
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
@ -105,6 +106,10 @@ class FrameRelaySwitch(Device):
|
|||||||
Deletes this Frame Relay switch.
|
Deletes this Frame Relay switch.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
for nio in self._nios.values():
|
||||||
|
if nio and isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
yield from self._hypervisor.send('frsw delete "{}"'.format(self._name))
|
yield from self._hypervisor.send('frsw delete "{}"'.format(self._name))
|
||||||
log.info('Frame Relay switch "{name}" [{id}] has been deleted'.format(name=self._name, id=self._id))
|
log.info('Frame Relay switch "{name}" [{id}] has been deleted'.format(name=self._name, id=self._id))
|
||||||
@ -156,6 +161,9 @@ class FrameRelaySwitch(Device):
|
|||||||
raise DynamipsError("Port {} is not allocated".format(port_number))
|
raise DynamipsError("Port {} is not allocated".format(port_number))
|
||||||
|
|
||||||
nio = self._nios[port_number]
|
nio = self._nios[port_number]
|
||||||
|
if isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
|
|
||||||
log.info('Frame Relay switch "{name}" [{id}]: NIO {nio} removed from port {port}'.format(name=self._name,
|
log.info('Frame Relay switch "{name}" [{id}]: NIO {nio} removed from port {port}'.format(name=self._name,
|
||||||
id=self._id,
|
id=self._id,
|
||||||
nio=nio,
|
nio=nio,
|
||||||
|
@ -32,6 +32,7 @@ log = logging.getLogger(__name__)
|
|||||||
|
|
||||||
from ...base_vm import BaseVM
|
from ...base_vm import BaseVM
|
||||||
from ..dynamips_error import DynamipsError
|
from ..dynamips_error import DynamipsError
|
||||||
|
from ..nios.nio_udp import NIOUDP
|
||||||
from gns3server.utils.asyncio import wait_run_in_executor
|
from gns3server.utils.asyncio import wait_run_in_executor
|
||||||
|
|
||||||
|
|
||||||
@ -312,6 +313,20 @@ class Router(BaseVM):
|
|||||||
if self._dynamips_id in self._dynamips_ids[self._project.id]:
|
if self._dynamips_id in self._dynamips_ids[self._project.id]:
|
||||||
self._dynamips_ids[self._project.id].remove(self._dynamips_id)
|
self._dynamips_ids[self._project.id].remove(self._dynamips_id)
|
||||||
|
|
||||||
|
if self._console:
|
||||||
|
self._manager.port_manager.release_tcp_port(self._console)
|
||||||
|
self._console = None
|
||||||
|
|
||||||
|
if self._aux:
|
||||||
|
self._manager.port_manager.release_tcp_port(self._aux)
|
||||||
|
self._aux = None
|
||||||
|
|
||||||
|
for adapter in self._slots:
|
||||||
|
if adapter is not None:
|
||||||
|
for nio in adapter.ports.values():
|
||||||
|
if nio and isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
|
|
||||||
if self in self._hypervisor.devices:
|
if self in self._hypervisor.devices:
|
||||||
self._hypervisor.devices.remove(self)
|
self._hypervisor.devices.remove(self)
|
||||||
if self._hypervisor and not self._hypervisor.devices:
|
if self._hypervisor and not self._hypervisor.devices:
|
||||||
@ -323,14 +338,6 @@ class Router(BaseVM):
|
|||||||
pass
|
pass
|
||||||
yield from self.hypervisor.stop()
|
yield from self.hypervisor.stop()
|
||||||
|
|
||||||
if self._console:
|
|
||||||
self._manager.port_manager.release_tcp_port(self._console)
|
|
||||||
self._console = None
|
|
||||||
|
|
||||||
if self._aux:
|
|
||||||
self._manager.port_manager.release_tcp_port(self._aux)
|
|
||||||
self._aux = None
|
|
||||||
|
|
||||||
self._closed = True
|
self._closed = True
|
||||||
|
|
||||||
@property
|
@property
|
||||||
@ -1226,6 +1233,8 @@ class Router(BaseVM):
|
|||||||
port_number=port_number))
|
port_number=port_number))
|
||||||
|
|
||||||
nio = adapter.get_nio(port_number)
|
nio = adapter.get_nio(port_number)
|
||||||
|
if isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
adapter.remove_nio(port_number)
|
adapter.remove_nio(port_number)
|
||||||
|
|
||||||
log.info('Router "{name}" [{id}]: NIO {nio_name} removed from port {slot_number}/{port_number}'.format(name=self._name,
|
log.info('Router "{name}" [{id}]: NIO {nio_name} removed from port {slot_number}/{port_number}'.format(name=self._name,
|
||||||
|
@ -34,9 +34,9 @@ import glob
|
|||||||
from .iou_error import IOUError
|
from .iou_error import IOUError
|
||||||
from ..adapters.ethernet_adapter import EthernetAdapter
|
from ..adapters.ethernet_adapter import EthernetAdapter
|
||||||
from ..adapters.serial_adapter import SerialAdapter
|
from ..adapters.serial_adapter import SerialAdapter
|
||||||
from ..nios.nio_udp import NIO_UDP
|
from ..nios.nio_udp import NIOUDP
|
||||||
from ..nios.nio_tap import NIO_TAP
|
from ..nios.nio_tap import NIOTAP
|
||||||
from ..nios.nio_generic_ethernet import NIO_GenericEthernet
|
from ..nios.nio_generic_ethernet import NIOGenericEthernet
|
||||||
from ..base_vm import BaseVM
|
from ..base_vm import BaseVM
|
||||||
from .ioucon import start_ioucon
|
from .ioucon import start_ioucon
|
||||||
import gns3server.utils.asyncio
|
import gns3server.utils.asyncio
|
||||||
@ -104,11 +104,19 @@ class IOUVM(BaseVM):
|
|||||||
@asyncio.coroutine
|
@asyncio.coroutine
|
||||||
def close(self):
|
def close(self):
|
||||||
|
|
||||||
yield from self.stop()
|
|
||||||
if self._console:
|
if self._console:
|
||||||
self._manager.port_manager.release_tcp_port(self._console)
|
self._manager.port_manager.release_tcp_port(self._console)
|
||||||
self._console = None
|
self._console = None
|
||||||
|
|
||||||
|
adapters = self._ethernet_adapters + self._serial_adapters
|
||||||
|
for adapter in adapters:
|
||||||
|
if adapter is not None:
|
||||||
|
for nio in adapter.ports.values():
|
||||||
|
if nio and isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
|
|
||||||
|
yield from self.stop()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def path(self):
|
def path(self):
|
||||||
"""Path of the iou binary"""
|
"""Path of the iou binary"""
|
||||||
@ -410,16 +418,16 @@ class IOUVM(BaseVM):
|
|||||||
nio = adapter.get_nio(unit)
|
nio = adapter.get_nio(unit)
|
||||||
if nio:
|
if nio:
|
||||||
connection = None
|
connection = None
|
||||||
if isinstance(nio, NIO_UDP):
|
if isinstance(nio, NIOUDP):
|
||||||
# UDP tunnel
|
# UDP tunnel
|
||||||
connection = {"tunnel_udp": "{lport}:{rhost}:{rport}".format(lport=nio.lport,
|
connection = {"tunnel_udp": "{lport}:{rhost}:{rport}".format(lport=nio.lport,
|
||||||
rhost=nio.rhost,
|
rhost=nio.rhost,
|
||||||
rport=nio.rport)}
|
rport=nio.rport)}
|
||||||
elif isinstance(nio, NIO_TAP):
|
elif isinstance(nio, NIOTAP):
|
||||||
# TAP interface
|
# TAP interface
|
||||||
connection = {"tap_dev": "{tap_device}".format(tap_device=nio.tap_device)}
|
connection = {"tap_dev": "{tap_device}".format(tap_device=nio.tap_device)}
|
||||||
|
|
||||||
elif isinstance(nio, NIO_GenericEthernet):
|
elif isinstance(nio, NIOGenericEthernet):
|
||||||
# Ethernet interface
|
# Ethernet interface
|
||||||
connection = {"eth_dev": "{ethernet_device}".format(ethernet_device=nio.ethernet_device)}
|
connection = {"eth_dev": "{ethernet_device}".format(ethernet_device=nio.ethernet_device)}
|
||||||
|
|
||||||
@ -750,6 +758,8 @@ class IOUVM(BaseVM):
|
|||||||
port_number=port_number))
|
port_number=port_number))
|
||||||
|
|
||||||
nio = adapter.get_nio(port_number)
|
nio = adapter.get_nio(port_number)
|
||||||
|
if isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
adapter.remove_nio(port_number)
|
adapter.remove_nio(port_number)
|
||||||
log.info("IOU {name} [id={id}]: {nio} removed from {adapter_number}/{port_number}".format(name=self._name,
|
log.info("IOU {name} [id={id}]: {nio} removed from {adapter_number}/{port_number}".format(name=self._name,
|
||||||
id=self._id,
|
id=self._id,
|
||||||
|
@ -22,7 +22,7 @@ Interface for generic Ethernet NIOs (PCAP library).
|
|||||||
from .nio import NIO
|
from .nio import NIO
|
||||||
|
|
||||||
|
|
||||||
class NIO_GenericEthernet(NIO):
|
class NIOGenericEthernet(NIO):
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Generic Ethernet NIO.
|
Generic Ethernet NIO.
|
||||||
|
@ -22,7 +22,7 @@ Interface for TAP NIOs (UNIX based OSes only).
|
|||||||
from .nio import NIO
|
from .nio import NIO
|
||||||
|
|
||||||
|
|
||||||
class NIO_TAP(NIO):
|
class NIOTAP(NIO):
|
||||||
|
|
||||||
"""
|
"""
|
||||||
TAP NIO.
|
TAP NIO.
|
||||||
|
@ -22,7 +22,7 @@ Interface for UDP NIOs.
|
|||||||
from .nio import NIO
|
from .nio import NIO
|
||||||
|
|
||||||
|
|
||||||
class NIO_UDP(NIO):
|
class NIOUDP(NIO):
|
||||||
|
|
||||||
"""
|
"""
|
||||||
UDP NIO.
|
UDP NIO.
|
||||||
|
@ -29,7 +29,7 @@ import asyncio
|
|||||||
|
|
||||||
from .qemu_error import QemuError
|
from .qemu_error import QemuError
|
||||||
from ..adapters.ethernet_adapter import EthernetAdapter
|
from ..adapters.ethernet_adapter import EthernetAdapter
|
||||||
from ..nios.nio_udp import NIO_UDP
|
from ..nios.nio_udp import NIOUDP
|
||||||
from ..base_vm import BaseVM
|
from ..base_vm import BaseVM
|
||||||
from ...schemas.qemu import QEMU_OBJECT_SCHEMA
|
from ...schemas.qemu import QEMU_OBJECT_SCHEMA
|
||||||
|
|
||||||
@ -719,7 +719,7 @@ class QemuVM(BaseVM):
|
|||||||
|
|
||||||
if self.is_running():
|
if self.is_running():
|
||||||
# dynamically configure an UDP tunnel on the QEMU VM adapter
|
# dynamically configure an UDP tunnel on the QEMU VM adapter
|
||||||
if nio and isinstance(nio, NIO_UDP):
|
if nio and isinstance(nio, NIOUDP):
|
||||||
if self._legacy_networking:
|
if self._legacy_networking:
|
||||||
yield from self._control_vm("host_net_remove {} gns3-{}".format(adapter_id, adapter_id))
|
yield from self._control_vm("host_net_remove {} gns3-{}".format(adapter_id, adapter_id))
|
||||||
yield from self._control_vm("host_net_add udp vlan={},name=gns3-{},sport={},dport={},daddr={}".format(adapter_id,
|
yield from self._control_vm("host_net_add udp vlan={},name=gns3-{},sport={},dport={},daddr={}".format(adapter_id,
|
||||||
@ -928,7 +928,7 @@ class QemuVM(BaseVM):
|
|||||||
mac = self._get_random_mac(adapter_id)
|
mac = self._get_random_mac(adapter_id)
|
||||||
network_options.extend(["-net", "nic,vlan={},macaddr={},model={}".format(adapter_id, mac, self._adapter_type)])
|
network_options.extend(["-net", "nic,vlan={},macaddr={},model={}".format(adapter_id, mac, self._adapter_type)])
|
||||||
nio = adapter.get_nio(0)
|
nio = adapter.get_nio(0)
|
||||||
if nio and isinstance(nio, NIO_UDP):
|
if nio and isinstance(nio, NIOUDP):
|
||||||
if self._legacy_networking:
|
if self._legacy_networking:
|
||||||
network_options.extend(["-net", "udp,vlan={},name=gns3-{},sport={},dport={},daddr={}".format(adapter_id,
|
network_options.extend(["-net", "udp,vlan={},name=gns3-{},sport={},dport={},daddr={}".format(adapter_id,
|
||||||
adapter_id,
|
adapter_id,
|
||||||
|
@ -30,6 +30,7 @@ import asyncio
|
|||||||
|
|
||||||
from pkg_resources import parse_version
|
from pkg_resources import parse_version
|
||||||
from .virtualbox_error import VirtualBoxError
|
from .virtualbox_error import VirtualBoxError
|
||||||
|
from ..nios.nio_udp import NIOUDP
|
||||||
from ..adapters.ethernet_adapter import EthernetAdapter
|
from ..adapters.ethernet_adapter import EthernetAdapter
|
||||||
from .telnet_server import TelnetServer # TODO: port TelnetServer to asyncio
|
from .telnet_server import TelnetServer # TODO: port TelnetServer to asyncio
|
||||||
from ..base_vm import BaseVM
|
from ..base_vm import BaseVM
|
||||||
@ -296,12 +297,18 @@ class VirtualBoxVM(BaseVM):
|
|||||||
# VM is already closed
|
# VM is already closed
|
||||||
return
|
return
|
||||||
|
|
||||||
yield from self.stop()
|
|
||||||
|
|
||||||
if self._console:
|
if self._console:
|
||||||
self._manager.port_manager.release_tcp_port(self._console)
|
self._manager.port_manager.release_tcp_port(self._console)
|
||||||
self._console = None
|
self._console = None
|
||||||
|
|
||||||
|
for adapter in self._ethernet_adapters:
|
||||||
|
if adapter is not None:
|
||||||
|
for nio in adapter.ports.values():
|
||||||
|
if nio and isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
|
|
||||||
|
yield from self.stop()
|
||||||
|
|
||||||
if self._linked_clone:
|
if self._linked_clone:
|
||||||
hdd_table = []
|
hdd_table = []
|
||||||
if os.path.exists(self.working_dir):
|
if os.path.exists(self.working_dir):
|
||||||
@ -781,7 +788,7 @@ class VirtualBoxVM(BaseVM):
|
|||||||
yield from self._control_vm("nic{} null".format(adapter_number + 1))
|
yield from self._control_vm("nic{} null".format(adapter_number + 1))
|
||||||
|
|
||||||
nio = adapter.get_nio(0)
|
nio = adapter.get_nio(0)
|
||||||
if str(nio) == "NIO UDP":
|
if isinstance(nio, NIOUDP):
|
||||||
self.manager.port_manager.release_udp_port(nio.lport)
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
adapter.remove_nio(0)
|
adapter.remove_nio(0)
|
||||||
|
|
||||||
|
@ -31,6 +31,8 @@ import shutil
|
|||||||
from pkg_resources import parse_version
|
from pkg_resources import parse_version
|
||||||
from .vpcs_error import VPCSError
|
from .vpcs_error import VPCSError
|
||||||
from ..adapters.ethernet_adapter import EthernetAdapter
|
from ..adapters.ethernet_adapter import EthernetAdapter
|
||||||
|
from ..nios.nio_udp import NIOUDP
|
||||||
|
from ..nios.nio_tap import NIOTAP
|
||||||
from ..base_vm import BaseVM
|
from ..base_vm import BaseVM
|
||||||
from ...utils.asyncio import subprocess_check_output
|
from ...utils.asyncio import subprocess_check_output
|
||||||
|
|
||||||
@ -70,11 +72,16 @@ class VPCSVM(BaseVM):
|
|||||||
@asyncio.coroutine
|
@asyncio.coroutine
|
||||||
def close(self):
|
def close(self):
|
||||||
|
|
||||||
self._terminate_process()
|
|
||||||
if self._console:
|
if self._console:
|
||||||
self._manager.port_manager.release_tcp_port(self._console)
|
self._manager.port_manager.release_tcp_port(self._console)
|
||||||
self._console = None
|
self._console = None
|
||||||
|
|
||||||
|
nio = self._ethernet_adapter.get_nio(0)
|
||||||
|
if isinstance(nio, NIOUDP):
|
||||||
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
|
|
||||||
|
self._terminate_process()
|
||||||
|
|
||||||
@asyncio.coroutine
|
@asyncio.coroutine
|
||||||
def _check_requirements(self):
|
def _check_requirements(self):
|
||||||
"""
|
"""
|
||||||
@ -310,7 +317,7 @@ class VPCSVM(BaseVM):
|
|||||||
port_number=port_number))
|
port_number=port_number))
|
||||||
|
|
||||||
nio = self._ethernet_adapter.get_nio(port_number)
|
nio = self._ethernet_adapter.get_nio(port_number)
|
||||||
if str(nio) == "NIO UDP":
|
if isinstance(nio, NIOUDP):
|
||||||
self.manager.port_manager.release_udp_port(nio.lport)
|
self.manager.port_manager.release_udp_port(nio.lport)
|
||||||
self._ethernet_adapter.remove_nio(port_number)
|
self._ethernet_adapter.remove_nio(port_number)
|
||||||
|
|
||||||
@ -361,13 +368,13 @@ class VPCSVM(BaseVM):
|
|||||||
|
|
||||||
nio = self._ethernet_adapter.get_nio(0)
|
nio = self._ethernet_adapter.get_nio(0)
|
||||||
if nio:
|
if nio:
|
||||||
if str(nio) == "NIO UDP":
|
if isinstance(nio, NIOUDP):
|
||||||
# UDP tunnel
|
# UDP tunnel
|
||||||
command.extend(["-s", str(nio.lport)]) # source UDP port
|
command.extend(["-s", str(nio.lport)]) # source UDP port
|
||||||
command.extend(["-c", str(nio.rport)]) # destination UDP port
|
command.extend(["-c", str(nio.rport)]) # destination UDP port
|
||||||
command.extend(["-t", nio.rhost]) # destination host
|
command.extend(["-t", nio.rhost]) # destination host
|
||||||
|
|
||||||
elif str(nio) == "NIO TAP":
|
elif isinstance(nio, NIOTAP):
|
||||||
# TAP interface
|
# TAP interface
|
||||||
command.extend(["-e"])
|
command.extend(["-e"])
|
||||||
command.extend(["-d", nio.tap_vm])
|
command.extend(["-d", nio.tap_vm])
|
||||||
|
Loading…
Reference in New Issue
Block a user