From 9e2043bfa8c48c1b73850bbb37642ca1e554d0b7 Mon Sep 17 00:00:00 2001 From: Julien Duponchelle Date: Tue, 10 May 2016 12:14:48 +0200 Subject: [PATCH] Ensure that the connection to docker is closed when leaving server Fix https://github.com/GNS3/gns3-gui/issues/1227 --- gns3server/modules/docker/__init__.py | 4 +++- gns3server/modules/docker/docker_vm.py | 7 ++++--- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/gns3server/modules/docker/__init__.py b/gns3server/modules/docker/__init__.py index 89dc3679..7060f7f6 100644 --- a/gns3server/modules/docker/__init__.py +++ b/gns3server/modules/docker/__init__.py @@ -61,7 +61,9 @@ class Docker(BaseManager): raise DockerError("Docker API version is {}. GNS3 requires a minimum API version of {}".format(version["ApiVersion"], DOCKER_MINIMUM_API_VERSION)) return self._connector - def __del__(self): + @asyncio.coroutine + def unload(self): + yield from super().unload() if self._connected: self._connector.close() diff --git a/gns3server/modules/docker/docker_vm.py b/gns3server/modules/docker/docker_vm.py index 94385c89..5a57961e 100644 --- a/gns3server/modules/docker/docker_vm.py +++ b/gns3server/modules/docker/docker_vm.py @@ -77,6 +77,7 @@ class DockerVM(BaseVM): self._console_resolution = console_resolution self._console_http_path = console_http_path self._console_http_port = console_http_port + self._console_websocket = None if adapters is None: self.adapters = 1 @@ -433,12 +434,12 @@ class DockerVM(BaseVM): telnet = AsyncioTelnetServer(reader=output_stream, writer=input_stream, echo=True) self._telnet_servers.append((yield from asyncio.start_server(telnet.run, self._manager.port_manager.console_host, self.console))) - ws = yield from self.manager.websocket_query("containers/{}/attach/ws?stream=1&stdin=1&stdout=1&stderr=1".format(self._cid)) - input_stream.ws = ws + self._console_websocket = yield from self.manager.websocket_query("containers/{}/attach/ws?stream=1&stdin=1&stdout=1&stderr=1".format(self._cid)) + input_stream.ws = self._console_websocket output_stream.feed_data(self.name.encode() + b" console is now available... Press RETURN to get started.\r\n") - asyncio.async(self._read_console_output(ws, output_stream)) + asyncio.async(self._read_console_output(self._console_websocket, output_stream)) @asyncio.coroutine def _read_console_output(self, ws, out):