From babdbca7d290fa2d126d534b4267379533ababbf Mon Sep 17 00:00:00 2001 From: ThomasV Date: Tue, 27 Mar 2012 12:51:50 +0400 Subject: [PATCH 1/1] *create method for garbage collection; it might be better to call it from elsewhere *test if sessions are closed --- stratum.py | 48 ++++++++++++++++++++++++++---------------------- 1 files changed, 26 insertions(+), 22 deletions(-) diff --git a/stratum.py b/stratum.py index f89fafd..deb58b9 100644 --- a/stratum.py +++ b/stratum.py @@ -31,21 +31,23 @@ class Processor(threading.Thread): def pop_request(self): return self.request_queue.get() + def collect_garbage(self): + # Deep copy entire sessions list and blank it + # This is done to minimise lock contention + with self.lock: + sessions = self.sessions[:] + self.sessions = [] + for session in sessions: + if not session.stopped(): + # If session is still alive then re-add it back + # to our internal register + self.add_session(session) + def run(self): if self.shared is None: raise TypeError("self.shared not set in Processor") while not self.shared.stopped(): - # Deep copy entire sessions list and blank it - # This is done to minimise lock contention - with self.lock: - sessions = self.sessions[:] - self.sessions = [] - for session in sessions: - if not session.stopped(): - # If session is still alive then re-add it back - # to our internal register - self.add_session(session) - + self.collect_garbage() session, request = self.pop_request() self.process(session, request) @@ -63,20 +65,22 @@ class Processor(threading.Thread): def update_from_blocknum(self,block_number): for session in self.sessions: - if session.numblocks_sub is not None: - response = { 'id':session.numblocks_sub, 'result':block_number } - self.push_response(session,response) + if not session.stopped(): + if session.numblocks_sub is not None: + response = { 'id':session.numblocks_sub, 'result':block_number } + self.push_response(session,response) def update_from_address(self,addr): for session in self.sessions: - m = session.addresses_sub.get(addr) - if m: - status = self.get_status( addr ) - message_id, last_status = m - if status != last_status: - session.subscribe_to_address(addr,message_id, status) - response = { 'id':message_id, 'result':status } - self.push_response(session,response) + if not session.stopped(): + m = session.addresses_sub.get(addr) + if m: + status = self.get_status( addr ) + message_id, last_status = m + if status != last_status: + session.subscribe_to_address(addr,message_id, status) + response = { 'id':message_id, 'result':status } + self.push_response(session,response) def get_status(self,addr): # return status of an address -- 1.7.1