From 76b6899cf2645d663802d320d10aba9640195e8f Mon Sep 17 00:00:00 2001 From: Neil Booth Date: Wed, 25 Jan 2017 08:01:48 +0900 Subject: [PATCH] Try to avoid asyncio log spew on shutdown Closes #106. This is a hacky workaround to an issue that needs to be fixed in Python's asyncio library (where I filed issue 487 on github) --- server/controller.py | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/server/controller.py b/server/controller.py index 2ef9b4444..8692e2775 100644 --- a/server/controller.py +++ b/server/controller.py @@ -12,6 +12,7 @@ import ssl import time import traceback +import warnings from bisect import bisect_left from collections import defaultdict from concurrent.futures import ThreadPoolExecutor @@ -247,6 +248,11 @@ async def main_loop(self): await self.shutdown_event.wait() self.logger.info('shutting down') await self.shutdown() + # Avoid log spew on shutdown for partially opened SSL sockets + try: + del asyncio.sslproto._SSLProtocolTransport.__del__ + except Exception: + pass self.logger.info('shutdown complete') def initiate_shutdown(self): @@ -543,7 +549,7 @@ def session_data(self, for_log): def lookup_session(self, session_id): try: session_id = int(session_id) - except: + except Exception: pass else: for session in self.sessions: @@ -617,7 +623,7 @@ def address_to_hashX(self, address): if isinstance(address, str): try: return self.coin.address_to_hashX(address) - except: + except Exception: pass raise RPCError('{} is not a valid address'.format(address))