This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

Author stevezh
Recipients davin, jnoller, pitrou, sbt, stevezh
Date 2017-11-13.06:00:29
SpamBayes Score -1.0
Marked as misclassified Yes
Message-id <1510552830.41.0.213398074469.issue32014@psf.upfronthosting.co.za>
In-reply-to
Content
When shutdown the manager, Server's handle_request will send back message to the manager, so is useless for the Server's shutdown method send back "None" to the manager?

Source code from Lib/multiprocessing/managers.py:

    def shutdown(self, c):
        '''
        Shutdown this process
        '''
        try:
            util.debug('manager received shutdown message')
            # Is useless here?
            c.send(('#RETURN', None))
        except:
            import traceback
            traceback.print_exc()
        finally:
            self.stop_event.set()

Server's handle_request may throw and catch exception because the conn is closed in _finalize_manager() after Server's shutdown method returns.

code from handle_request():

        try:
            c.send(msg)
        except Exception as e:
            try:
                c.send(('#TRACEBACK', format_exc()))
            except Exception:
                pass

code from _finalize_manager():

            try:
                conn = _Client(address, authkey=authkey)
                try:
                    dispatch(conn, None, 'shutdown')
                finally:
                    conn.close()
            except Exception:
                pass

Also the Server's shutdown method only used by manager class.
History
Date User Action Args
2017-11-13 06:00:30stevezhsetrecipients: + stevezh, pitrou, jnoller, sbt, davin
2017-11-13 06:00:30stevezhsetmessageid: <1510552830.41.0.213398074469.issue32014@psf.upfronthosting.co.za>
2017-11-13 06:00:30stevezhlinkissue32014 messages
2017-11-13 06:00:29stevezhcreate