Ver Fonte

Merge pull request #589 from hathawsh/master

Unregister file descriptors when streams close.
Mike Naberezny há 10 anos atrás
pai
commit
20e47d8b09
1 ficheiros alterados com 6 adições e 0 exclusões
  1. 6 0
      supervisor/supervisord.py

+ 6 - 0
supervisor/supervisord.py

@@ -220,6 +220,9 @@ class Supervisor:
                             'read event caused by %(dispatcher)r',
                             'read event caused by %(dispatcher)r',
                             dispatcher=dispatcher)
                             dispatcher=dispatcher)
                         dispatcher.handle_read_event()
                         dispatcher.handle_read_event()
+                        if (not dispatcher.readable()
+                                and not dispatcher.writable()):
+                            self.options.poller.unregister(fd)
                     except asyncore.ExitNow:
                     except asyncore.ExitNow:
                         raise
                         raise
                     except:
                     except:
@@ -233,6 +236,9 @@ class Supervisor:
                             'write event caused by %(dispatcher)r',
                             'write event caused by %(dispatcher)r',
                             dispatcher=dispatcher)
                             dispatcher=dispatcher)
                         dispatcher.handle_write_event()
                         dispatcher.handle_write_event()
+                        if (not dispatcher.readable()
+                                and not dispatcher.writable()):
+                            self.options.poller.unregister(fd)
                     except asyncore.ExitNow:
                     except asyncore.ExitNow:
                         raise
                         raise
                     except:
                     except: