mirror of
https://github.com/GNS3/gns3-server
synced 2025-01-02 12:10:56 +00:00
Fix ConnectionResetError issues and switch to aiohttp version 3.4.4. Fixes #1474.
This commit is contained in:
parent
030714ae80
commit
f76b329cba
@ -449,6 +449,7 @@ class Compute:
|
|||||||
if action == "ping":
|
if action == "ping":
|
||||||
self._cpu_usage_percent = event["cpu_usage_percent"]
|
self._cpu_usage_percent = event["cpu_usage_percent"]
|
||||||
self._memory_usage_percent = event["memory_usage_percent"]
|
self._memory_usage_percent = event["memory_usage_percent"]
|
||||||
|
#FIXME: slow down number of compute events
|
||||||
self._controller.notification.controller_emit("compute.updated", self.__json__())
|
self._controller.notification.controller_emit("compute.updated", self.__json__())
|
||||||
else:
|
else:
|
||||||
await self._controller.notification.dispatch(action, event, compute_id=self.id)
|
await self._controller.notification.dispatch(action, event, compute_id=self.id)
|
||||||
|
@ -45,14 +45,14 @@ class NotificationHandler:
|
|||||||
request.app['websockets'].add(ws)
|
request.app['websockets'].add(ws)
|
||||||
asyncio.ensure_future(process_websocket(ws))
|
asyncio.ensure_future(process_websocket(ws))
|
||||||
with notifications.queue() as queue:
|
with notifications.queue() as queue:
|
||||||
while True:
|
try:
|
||||||
try:
|
while True:
|
||||||
notification = await queue.get_json(1)
|
notification = await queue.get_json(1)
|
||||||
if ws.closed:
|
if ws.closed:
|
||||||
break
|
break
|
||||||
await ws.send_str(notification)
|
await ws.send_str(notification)
|
||||||
except asyncio.futures.CancelledError:
|
finally:
|
||||||
break
|
if not ws.closed:
|
||||||
finally:
|
await ws.close()
|
||||||
request.app['websockets'].discard(ws)
|
request.app['websockets'].discard(ws)
|
||||||
return ws
|
return ws
|
||||||
|
@ -191,8 +191,6 @@ class ProjectHandler:
|
|||||||
msg = json.dumps({"action": action, "event": msg}, sort_keys=True)
|
msg = json.dumps({"action": action, "event": msg}, sort_keys=True)
|
||||||
log.debug("Send notification: %s", msg)
|
log.debug("Send notification: %s", msg)
|
||||||
await response.write(("{}\n".format(msg)).encode("utf-8"))
|
await response.write(("{}\n".format(msg)).encode("utf-8"))
|
||||||
except asyncio.futures.CancelledError as e:
|
|
||||||
break
|
|
||||||
except asyncio.futures.TimeoutError:
|
except asyncio.futures.TimeoutError:
|
||||||
await response.write("{}\n".format(json.dumps(ProjectHandler._getPingMessage())).encode("utf-8"))
|
await response.write("{}\n".format(json.dumps(ProjectHandler._getPingMessage())).encode("utf-8"))
|
||||||
project.stop_listen_queue(queue)
|
project.stop_listen_queue(queue)
|
||||||
|
@ -50,11 +50,8 @@ class NotificationHandler:
|
|||||||
await response.prepare(request)
|
await response.prepare(request)
|
||||||
with controller.notification.controller_queue() as queue:
|
with controller.notification.controller_queue() as queue:
|
||||||
while True:
|
while True:
|
||||||
try:
|
msg = await queue.get_json(5)
|
||||||
msg = await queue.get_json(5)
|
await response.write(("{}\n".format(msg)).encode("utf-8"))
|
||||||
await response.write(("{}\n".format(msg)).encode("utf-8"))
|
|
||||||
except asyncio.futures.CancelledError:
|
|
||||||
break
|
|
||||||
|
|
||||||
@Route.get(
|
@Route.get(
|
||||||
r"/notifications/ws",
|
r"/notifications/ws",
|
||||||
@ -71,14 +68,15 @@ class NotificationHandler:
|
|||||||
request.app['websockets'].add(ws)
|
request.app['websockets'].add(ws)
|
||||||
asyncio.ensure_future(process_websocket(ws))
|
asyncio.ensure_future(process_websocket(ws))
|
||||||
with controller.notification.controller_queue() as queue:
|
with controller.notification.controller_queue() as queue:
|
||||||
while True:
|
try:
|
||||||
try:
|
while True:
|
||||||
notification = await queue.get_json(5)
|
notification = await queue.get_json(5)
|
||||||
if ws.closed:
|
if ws.closed:
|
||||||
break
|
break
|
||||||
await ws.send_str(notification)
|
await ws.send_str(notification)
|
||||||
except asyncio.futures.CancelledError:
|
finally:
|
||||||
break
|
if not ws.closed:
|
||||||
finally:
|
await ws.close()
|
||||||
request.app['websockets'].discard(ws)
|
request.app['websockets'].discard(ws)
|
||||||
|
|
||||||
return ws
|
return ws
|
||||||
|
@ -229,11 +229,8 @@ class ProjectHandler:
|
|||||||
await response.prepare(request)
|
await response.prepare(request)
|
||||||
with controller.notification.project_queue(project) as queue:
|
with controller.notification.project_queue(project) as queue:
|
||||||
while True:
|
while True:
|
||||||
try:
|
msg = await queue.get_json(5)
|
||||||
msg = await queue.get_json(5)
|
await response.write(("{}\n".format(msg)).encode("utf-8"))
|
||||||
await response.write(("{}\n".format(msg)).encode("utf-8"))
|
|
||||||
except asyncio.futures.CancelledError as e:
|
|
||||||
break
|
|
||||||
|
|
||||||
if project.auto_close:
|
if project.auto_close:
|
||||||
# To avoid trouble with client connecting disconnecting we sleep few seconds before checking
|
# To avoid trouble with client connecting disconnecting we sleep few seconds before checking
|
||||||
@ -263,16 +260,16 @@ class ProjectHandler:
|
|||||||
request.app['websockets'].add(ws)
|
request.app['websockets'].add(ws)
|
||||||
asyncio.ensure_future(process_websocket(ws))
|
asyncio.ensure_future(process_websocket(ws))
|
||||||
with controller.notification.project_queue(project) as queue:
|
with controller.notification.project_queue(project) as queue:
|
||||||
while True:
|
try:
|
||||||
try:
|
while True:
|
||||||
notification = await queue.get_json(5)
|
notification = await queue.get_json(5)
|
||||||
if ws.closed:
|
if ws.closed:
|
||||||
break
|
break
|
||||||
await ws.send_str(notification)
|
await ws.send_str(notification)
|
||||||
except asyncio.futures.CancelledError:
|
finally:
|
||||||
break
|
if not ws.closed:
|
||||||
finally:
|
await ws.close()
|
||||||
request.app['websockets'].discard(ws)
|
request.app['websockets'].discard(ws)
|
||||||
|
|
||||||
if project.auto_close:
|
if project.auto_close:
|
||||||
# To avoid trouble with client connecting disconnecting we sleep few seconds before checking
|
# To avoid trouble with client connecting disconnecting we sleep few seconds before checking
|
||||||
|
@ -221,6 +221,7 @@ class Route(object):
|
|||||||
response = Response(request=request, route=route)
|
response = Response(request=request, route=route)
|
||||||
response.set_status(408)
|
response.set_status(408)
|
||||||
response.json({"message": "Request canceled", "status": 408})
|
response.json({"message": "Request canceled", "status": 408})
|
||||||
|
raise # must raise to let aiohttp know the connection has been closed
|
||||||
except aiohttp.ClientError:
|
except aiohttp.ClientError:
|
||||||
log.warning("Client error")
|
log.warning("Client error")
|
||||||
response = Response(request=request, route=route)
|
response = Response(request=request, route=route)
|
||||||
|
@ -102,7 +102,10 @@ class WebServer:
|
|||||||
return
|
return
|
||||||
|
|
||||||
# close websocket connections
|
# close websocket connections
|
||||||
for ws in set(self._app['websockets']):
|
websocket_connections = set(self._app['websockets'])
|
||||||
|
if websocket_connections:
|
||||||
|
log.info("Closing {} websocket connections...".format(len(websocket_connections)))
|
||||||
|
for ws in websocket_connections:
|
||||||
await ws.close(code=aiohttp.WSCloseCode.GOING_AWAY, message='Server shutdown')
|
await ws.close(code=aiohttp.WSCloseCode.GOING_AWAY, message='Server shutdown')
|
||||||
|
|
||||||
if self._server:
|
if self._server:
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
jsonschema>=2.4.0
|
jsonschema>=2.4.0
|
||||||
aiohttp==3.2.1
|
aiohttp==3.4.4
|
||||||
aiohttp-cors==0.7.0
|
aiohttp-cors==0.7.0
|
||||||
Jinja2>=2.7.3
|
Jinja2>=2.7.3
|
||||||
raven>=5.23.0
|
raven>=5.23.0
|
||||||
|
Loading…
Reference in New Issue
Block a user